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. MANUAL SUMMARY 
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CHAPTER 1: GENERAL OPERATING INFORMATION 
To familiarize the user with the Model 30, various topics are introduced. 


CHAPTER 2: USING THE MODEL 30 KEYBOARD 


The capabilities of the Model 30, strictly as a calculator, are described. Editing 
capabilities are presented. Mathematical topics include variables, trigonometric 
operations, and logical evaluation. 


CHAPTER 3: PROGRAMMING AND PROGRAMMING STATEMENTS 


The programming language, BASIC, is presented. Programming statements are 
individually discussed. Examples, using particular statements, are given. 


CHAPTER 4: PROGRAMMING-RELATED INFORMATION 


Program viewing, editing, and debugging are discussed individually. Useful keys 
and commands, related to these topics, are presented. The Model 30 memory is 
described. 


CHAPTER 5: USING A TAPE CASSETTE 


Tape cassettes are described. Each tape cassette command is_ individually 
discussed. 


CHAPTER 6: SPECIAL FUNCTION KEYS 
The uses of these keys as typing-aids, as functions, and as programs are discussed. 


APPENDIX A: CALCULATOR AND PRINTER INSTALLATION PROCEDURE 


Initia) turn-on and inspection procedures are presented. This appendix should be 
read immediately upon arrival of the calculator and printer. 


APPENDIX 8: GENERAL OWNER’S INFORMATION 
Equipment supplied, service information, etc. are all described. 


APPENDIX C: ROM OPTIONS 
Available ROM’‘s are described and a general installation procedure is given. 


APPENDIX D: MODEL 60 CARD READER 
For those who have purchased this accessory, a general description is given. 


APPENDIX E: ERROR CODES | 
The error codes and messages are listed along with some additional explanations. 


APPENDIX F: PRINTER OPERATING PROCEDURES 


Printing commands and examples are given. A table, which shows the ASCII charac- 
ters that can be output using the FORMAT B statement, is included. 
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This book is organized both: 


® With a logical arrangement of topics so that it 
can be read straight through, if desired; and 


e Asa reference guide, with major topics ‘tab- 
bed’ at the right side of appropriate pages. 


The quick index to the right of this page sepa- 
rates the tabbed information by chapter. 


It is expected that the tabbed material will be 
most beneficial as a reference guide to Chapter 3; 
where each program. statement is tabbed, and to 
Chapter 5, where each tape command is tabbed. 


Wherever possible, major topics are self-contained; 
that is, it’s not necessary to read an entire 
chapter to extract one idea. 


> However, since Chapter 1 discusses the special 
features of the calculator, you should understand 

= the material in this chapter before going on to 
isolated topics. 
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ASSIGNMENT 
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DISP 
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CHAPTER 4: PROGRAMMING-RELATED INFORMATION 
STANDARD PROGRAMMING COMMANDS 


RUN key 

STOP key 

CONT key 
TIME-SAVING COMMANDS 

AUTO = key 

REN command 
PROGRAM VIEWING 

FETCH key 

4 and ft keys 

LIST key ; 
PROGRAM EDITING 


BACK, FORWARD and INSERT oe 


RECALL key 

DELETE LINE key 

DEL command 

SCRATCH key 
PROGRAMMING CHECKS 

TRACE and NORMAL keys 

STEP key 

Checking a Halted Proatani 
CALCULATOR MEMORY 

LIST key 

INIT key 
ADDITIONAL COMMANDS 

INIT key 

PTAPE command 

SEC command 


CHAPTER 5: USING A TAPE CASSETTE 


THE TAPE CASSETTE 


Specifications 

Other Cassettes 
Inserting Tape Cassettes 
Protecting Cassettes 
Storing Cassettes 
Cleaning the Tape Head 
Tape File Structure 
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CASSETTE COMMANDS 
Programmability 
Syntax 

MARK 
Marking New Tapes 
Marking a Used Tape 

STORE 

LOAD 

LINK 

MERGE 

FIND 

REWIND 

STORE DATA 

LOAD DATA 

STORE KEY 

LOAD KEY 

LOAD BIN 

TLIST 

PERIPHERAL CASSETTES 

CASSETTE SYNTAXES 


CHAPTER 6: SPECIAL FUNCTION KEYS 


ENTERING AND EXITING KEY MODE 
KEYS AS TEXT 
KEYS AS FUNCTIONS 
KEYS AS PROGRAMS 
ADDITIONAL KEY OPERATIONS 
Keyboard Commands 
Cassette Commands 
Key Overlays 
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APPENDIX A: CALCULATOR AND PRINTER INSTALLATION PROCEDURES 


THE CALCULATOR .. «. 
Inspection Procedure 
Power Requirements 
Power Outlets 
Grounding Requirements 
Fuses ; 

Initial Turn-On 
Cleaning the Calculator 

PRIMARY PRINTERS 

THE 9866A PRINTER 
Description 
initial Turn-On 
Loading Printer Paper 


APPENDIX B: GENERAL OWNER'’S INFORMATION 


EQUIPMENT SUPPLIED 
SERVICE CONTRACTS 
PROGRAM PACS 
KEYBOARD MAGAZINE 
‘ MEMORY OPTIONS 
OPTIONAL EQUIPMENT 
CONNECTING PERIPHERAL DEVICES 


APPENDIX C: ROM OPTIONS 


GENERAL DESCRIPTION 
INSTALLING A PLUG-IN ROM 
HOW TO ORDER A ROM 
THE ROM’S 

Matrix Operations 

Plotter Control 

Extended 1/0 

String Variables 

Terminal 


APPENDIX D: MODEL 60 CARD READER 


GENERAL INFORMATION 
CARD READER OPERATION 
Inspection 
Installation 
Using the Card Reader 
Encoding 
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APPENDIX E: ERROR CODES 


RECOVERABLE vs NON-RECOVERABLE ERRORS . E-1 
ERROR MESSAGES . E-2 
APPENDIX F: PRINTER OPERATING PROCEDURES 
PRINTER SELECT CODE . F-1 
THE 9866A PRINTER : . F-1 
THE 9861A OUTPUT TYPEWRITER . F-I 
THE TELETYPE 38 ASR DATA TERMINAL . F4 
PRINTER CHARACTER CODES . F-5 
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Figure A-2. Switch Setting for the Namnint Powseline: voltages 
Figure A-3. Connecting the 9866A Printer 
Figure B-1. Power Cords 
Figure B-2. Connecting an 1/0 Card 
Figure C-1. Plug-in ROM’S ; 
Figure D-1. 9860A Marked Card Reader 
Figure D-2. The Program Card 
Figure E-1. Model 9830A Keyboard 
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Table B-1. Standard Accessories Supplied 
Table B-2. 9800 Series Calculator Peripherals 
Table D-1. Card Reader Equipment 


i Table D-2. Key Codes 


Table E-1. Additional Error- Wiessage Exolanauons 

Table E-2. Error Codes 

Table F-1. Printer Operations 
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CAUTION 


The inspection procedure for the Model 30 is presented in Appendix A of 
this book. Please refer there: 


@ if the calculator and printer have not been inspected, or 


e If there is any doubt regarding the compziibility of the calculator 
power requirements to the voltage in your area. 


Otherwise, the calcuiator and printer could be severely damaged. 











F F Chapter 1 
GENERAL OPERATING INFORMATION 


It is assumed here that the Model 30 is set up to operate in your area — if there is any 
doubt whatsoever, please refer to Appendix A of this book. 
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This chapter contains background material for the remaining chapters in this book. 
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—>—> PREPARING THE CALCULATOR FOR USE —-—o 


There are a few things you should check each time you plan to use the calculator. 


If the calculator is turned off: 


, i LINE 
@ Set the OFF/ON switch to the ON tion. 
/ON swite e@ position... BE on 


, @ When the following display appears, the calculator is ready to operate: 


@ If the display remains blank, refer to Appendix A for plug-in instructions. 


If the calculator is turned on and the display is blank: 


® Hold the STOP key down until STOP appears on the display. 

@ if the display remains blank, turn the calculator off, then a few seconds later, 
turn it on again. 

e If the display still remains blank, refer to Appendix A for plug-in instructions. 


If the calculator is turned on and the display is not blank: 


@ if you wish to do calculations, just follow the arithmetic rules discussed in 
Chapter 2. 


e If you wish to do programming, first check with other users to ensure that 
nothing important is in memory (memory is the term used to denote the area in 
which a user can put pertinent information — such as a program); if there is no 
need to retain the information in memory, turn the calculator off, then a few 
seconds later, on again. This procedure erases whatever was previously in memory. 
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THE KEYBOARD 





~>—~> CHARACTERISTICS OF THE MODEL 30 <-> 





A representation of the Model 30 keyboard is shown in Figure 1-1. The keyboard is 
divided into specified areas as described below. 


Alphanumeric Keys — This area acts very much like a standard typewriter 
keyboard. If, for instance, you want to display the dollar sign, S, you must have 
the SHIFT key held down when you press i. It differs from a standard 
typewriter in that letters always appear in upper case on the display. 

Numeric Keys — This area conveniently locates a set of numbers to the left of the 
five arithmetic keys. If, however, you feel more comfortable using the other set 
of numbers (in the alphanumeric region), go right ahead. It makes no difference 
to the calculator. 

Arithmetic Keys — The standard arithmetic operators, addition, subtraction, 
multiplication, division, and exponentiation, are located here. 

Special Function Keys — The keys in the upper left-hand region of the keyboard, 
fo through f,, add considerable flexibility to the calculator. These keys are 
discussed .n Chapter 6. 

The rest of the keys in the upper half of the keyboard are helpful in a variety of 
ways. Some are especially useful! as editing tools, while others have more specific 
uses. The keys are described, in appropriate places, throughout this book. 


Keys that are the same color have similar operating characteristics. As you become more 
familiar with the Model 30, these similarities will become evident. 


Here are a few more topics related to keyboard operations: 


Spacing — In general it makes no difference what spacing you use either in 
calculating or in programming; for example, 4+6 or 4+ 6 are interpreted the same 
by the calculator. There are, however, certain instances when you can set a 
specific spacing for outputting purposes, say, in PRINT and DISP statements, 
which are discussed in Chapter 3. 

Repetition of Operations — Most keys, when held down for about two seconds, 
rapidly repeat their operation. With certain editing keys, this is a particularly 
useful! feature. 

Upper and Lower Case Alphabetics — The display on the calculator shows letters 
only in upper case, But if you have a printer with lower case capabilities, 
information can be printed that way; more about that later when the PRINT 
statement is discussed. 


@ Symbo! — !f you ever need this symbol, you can obtain it by pressing the 
RESULT key when the SHIFT key is depressed. 
Fk Symbol — When the display is clear and awaiting inputs, ‘-’ is located in the 


left-hand corner of the display; the first character then keyed in replaces this 
symbol in the display. ‘r’ also appears at the end of a program line that is 
returned to the display from memory. 
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Up to 32 characters can appear on the display at any one time. 
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Editing Keys, etc. 















Tape Cassette Door 
Cassette Door Release 


Arithmetic Keys 


32 -Character Display 


s OFF/ON Switch 
\ Slide-out Cards 


Atphanumeric Keys 


Figure 1-1. The Model 30 Calculator 


Special Function Keys 


Numeric Keys 





LINE LENGTH 





Even though only 32 characters can be displayed at any one time, up to 80 characters 
can be keyed into the same expression. After the 32nd character is keyed in, additional 

== characters that are keyed in cause the display region to be shifted to the left. After the 
72nd character is keyed in, a soft beep occurs, informing the user that only eight more 
characters can be keyed in. 


Any portion of the line can be reviewed on the display as you wil! see in Chapter 2. 


RANGE 


The calculating range of the Model 30 is 9. 99999999999 X 10°? through —! X 10°°, 
0, and 1 X 10°? through 9.99999999999 x 10°°, The pictorial representation below 
shows an exaggerated representation of the non-defined (cross hatched) areas. 


0 





—9.99999999999 x 10°” . —1 xX 107%? 0 1x 1079? 9.99999999999 x 10°° 
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‘ The calculator has an allocated amount of user memory, Tee amount of memory is 

. expressed in ‘words’, which is a compuier-orients« feasuring stick. By keying «wi a few 
programs and seeing how much (or hark aaetey memory Is used by these programs, you 

_will soon hevz a good fee! fs. 7st how large a program you can input. (For the 
computer oriented, yuu’ _betiterested to know that each word is made up of 16 bits — 
two bytes. --< eaiculator memory is discussed in Chapter 4. 





7 mee TEE, SIR ee ep ne ee, = = 
” - ee ee ea eee te en rte 


ate ee 


> 
Bo 
>= 
er 
ar 
qu 
o 








1-4 





—>——> CHARACTERISTICS OF THE MODEL 30 <—<o 


{continued) 





ERROR MESSAGES 


Occasionally the word, ERROR, followed by a number, will appear on the display at the 
same time that the calculator makes a soft beeping sound. This indicates that an error has 
occurred. The number references an error message that helps to pinpoint the cause of the 
error. 


If an error message appears during an attempt to run a program, the program line in 
which the error occurs will be referenced, also. 


A complete listing of the error messages appears both on a slide-out card underneath the 


Model 30 and in Appendix E of this book. An explanation of recoverable versus 
non-recoverable errors is given in Appendix E. 


A PREVIEW OF THE KEYS <-o-o om 





In general, when the CLEAR key is pressed, whatever was previously on the 


mame display will be erased; but the following exceptions may occur: 


@ tf, when the CLEAR key is pressed, the following display appears: 
(EEYF \) 


the Special Function mode has somehow been previously accessed (see Chapter 
6). To get out of this mode and to clear the display, press: 


@ If the display ‘blanks out’ while the calculator is turned on, hold the STOP key 
down until STOP appears on the display; then you can press the CLEAR key and 
continue inputting. If your display continues to go blank, you may find that your 
printer is not properly attached to the calculator; in this case, see Appendix A. 


@ If you can’t locate your problem and yet you seem to have no contro! over the 
keyboard, turn the calculator off and then, in a few seconds, on again. (This 
procedure may be the last resort in some cases, though; for if you had previously 
put something into the user’s memory area, it is erased by turning the Model 30 
off.) 


Almost every sequence of keys that is pressed to accomplish a goal needs to be 
completed with the EXECUTE key; when this key is pressed, the previous 
instructions to the calculator are performed. One major exception to this rule 
comes about when inputting program lines to memory (see below). Other 
exceptions are keys, such as ®5 and xi), which are immediately executed when 


pressed. 





At the completion of each program tine that is keyed in, the END OF 
LINE key must be pressed to put the information in memory. 
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{continued} 


Here are the rules that outputs in standard mode follow: 
@ No more than 10 digits total can be output, with no more than 9 digits to the 
right of the decimal point; for example: 
9876543210.6 would be output as 9876543211 (notice the tenth digit is 
rounded); and 


0123456789 would be output as 0.012345679 (at least one digit is always 
displayed to the left of the decimal point; so, in this case, the ninth digit to 
the right of the decima! point is rounded from 8 to 9). 


@ Excess zeros to the right of the decima! point are suppressed; for example: 
32.1000 would be output as 32.1; but 
32.111199999 would be rounded to 32.11120000 (in this case, the zeros are 
output since they were the result of rounding). 


@ As shown on the pictorial on page 2-1, mumbers outside the range 
[—10,000,000,000 through —.01, 0, +.01 through +10,000,000,000]} are output in 
a scientific notation. The form is the same as float-5 notation. 
Here are some numbers and their output form when standard notation is used: 


Standard Output 


12.03 12.03 

18.7654 18.7654 

15 15 

—832.600 —832.6 
987654321 .234 987654321 .2 
123456789123.0 1.23457E+11 
~-.0004 —4.00000E—04 





Fixed-point notation is commonly used for a variety of problems. In ‘fixed-point’ the 
user can specify the number of digits to appear to the right of the decimal point; in 
payroll problems for instance, two digits to the right of the decimal point would be 
required — hence ‘fixed-2 notation’. This notation can be obtained if you press: 


=a) 


Now the results of calculations will appear with two digits to the right of the decimal 
point. For instance, if you press: 


QA@0e!| 


gomum 





\) 


(- 


The results of other calculations now wi!l appear with two digits to the right of the 
decimal point, also. However, the result of a calculation could be too large to appear in 
fixed-point form. In such circumstances, the calculator reverts to floating-point (in our 
case, it would revert to float-2). Floating-point notation is described at the conclusion of 
the fixed-point discussion. 
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Fixed-O- through fixed-11 notation can be specified. In each case the numeric indicates 
the number of digits that will appear to the right of the decimal point. (However, in 
fixed-0, since there are no digits to the right of the decimal point, the decimal point is 
omitted.} 


Here’s another example. Press: 
=00/|)“0@ 


Here are some numbers and their output form if, say, fixed-3 notation is used: 
Fixed-3 Output 





wAcOM aM 


18 18.000 
.000006 0.000 
—2.7531 —2.753 
4.56789 4.568 
1234567891234.5 1.235E+12* 


+ If fixed-point notation is specified and the result of a calculation has more than 12 
digits to the left of the decimal point, the calculator temporarily reverts to floating-point. 
Notice, however, that in this example, three digits are retained to the right of the decimal 
point to parallel the desired fixed-point notation. 


Occasionally a result, slightly different from the expected, may appear on the display; the 
two topics following the floating-point discussion — Significant Digits and Rounding — 
explain these situations. 
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Floating-point (often called scientific notation) is a convenient form when the results of 
calculations are either very large or very small. Its form is as follows: 


+7.Z +--+ ZEtZZ 


® The first non-zero digit of a number is the first digit displayed (if the number is 
negative, a minus sign precedes this digit); 

@ A decimal point follows the first digit; 

@ Some digits follow the decimal point; the amount is determined by the specified 
floating-point form (e.g., in float-5, five digits would follow the decimal point); 


@ Then the character ‘E’ appears, followed by a sign and two digits — this is the 
exponent, representing a positive or negative power of ten, which indicates the 
direction and the number of places that the decimal point would have to be 
moved to express the number in fixed-point form. 


Here’s an example. Press: 


@(!)-O@00)) 


If the sign following the E is positive (as in this example}, then the decimal point can be 
moved to the right the number of places indicated by the exponent (in this case, 4) to 


express the number in fixed-point form. 
{continued} 
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THE FORMAT KEYS 


{continued} 


Here’s another example. Press: 
=O) |) 2OOGH 


Since the sign of the exponent in this example is minus, the decimal point can be moved 
to the left three places {as indicated by the exponent ‘03'} to express the number in 
fixed-point form. 
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Float-@ through float-11 can all be specified. In each case, the numeric indicates the 
number of digits that will appear immediately to the right of the decimal point. 
(However, in float-@, since there are no digits to the right of the decimal point, the 
decimal point is omitted.) 


Here are some numbers and their output form if, say, float-2 notation is used: 


Float-2 Output 


—3.2 —3.20E+00 
271 2.71E+02 
26.3777 2.64E+01 
.0004 4.00E—-04 
2.4E78" 2.40E+78 


+ This entry could be keyed in by using either of the following two keys: 


or the alphabetic key (e) 


In numerical inputs, these two keys are interpreted as a floating-point input. For 
instance, the previous example can be keyed in and executed as: 


QOUVEVe 


For the number, 6000, the following entries would all be equivalent: 


OOOO OOO « DOB® 





SIGNIFICANT DIGITS 





The number of digits output in a calculation depends on the notation that is used. 
However, regardless of the notation, the Model 30 internally retains 12 significant digits 
for the output; that is, it catculates to 12-point accuracy. 


The 12-point accuracy can always be displayed on outputs if either fixed-11 or float-11 
notation is specified. But in any notation, if more than twelve digits are to be output, all 
digits after the twelfth are truncated and replaced by zeros; for example, in fixed-5 
notation, when executed, the number 123456789.56789 (having 14 digits} would be 





displayed as: 





Notice that the last two digits of the number (8 and 9) are ignored and zeros are 
displayed in their place — since the ‘7’ preceding them was the twelfth significant digit. 
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If the result of a calculation has fewer than thirteen digits, tt is rounded if there are more 
digits to the right of the decima! point than the specified notation will allow. The 
rounding is performed as follows: the first excess digit is checked; if its value is 5 or 
above, the digit immediately preceding it is incremented (rounded-up) by one. For 


example, press: 


=0({] ~«a0000))) 


The ‘2’ is rounded to ‘3’ since it is the last allowable digit to be displayed in this 
notation and since the digit following it is a ‘7’. Now key in: 


=(||]~ @O0@a 


in this example, the digit checked is the one following the 4. Since its value {2} is less 
than 5, it, together with the following digits, is truncated (rounded-down}). 


\3 
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The five basic numerical operations and their respective symbols are as follows: addition 
(+), subtraction (—), multiplication (+), division (/), and exponentiation (fT). 





CALCULATING 


To perform basic calculations, such as 4 multiplied by 3, simply do the following. Press: 


oole 


In standard notation, the following result appears on the display: 
(iz \ 


To raise 2 to the third power (2°), press: 


Gio J 


Notice, however, that 2> must be keyed in as 2t(-3); that is, parentheses are required to 
separate the minus sign from the exponentiation symbol. 


The EXECUTE key must be pressed to evaluate any keyed- 
in expression. 


AtEm aM 


aAncomae 
on 
rn 


To divide 10 by 2.5, press: 


QOOBO@Q!:| Ca 


MHACOAaRs 





ARITHMETIC HIERARCHY 


In a mathematical expression (which is a sequence of numbers separated by numeric 
symbols), there is a prescribed order of execution: the order of execution, called the 
hierarchy, is the same as the order commonly used in standard arithmetic; it is: 


1. ft highest precedence 
2. * / 
3. + — lowest precedence 


The order of execution is from highest precedence to lowest precedence. 


When an expression contains two or more symbols at the same level in the hierarchy, the 
order of execution is from left to right. 


The prescribed order of execution can be altered if parentheses are used; operations 
within parentheses are performed prior to operations outside parentheses regardless of the 
hierarchy. Furthermore, parentheses can be nested (i.e., parentheses within parentheses 
are allowed): when nesting occurs, the ‘deepest’ nest is calculated first; e.g., in (5*(4—2}), 
the portion (4—2) is simplified first. 











a pecan Hatin an aad 


In the following two examples, the internal step-by-step procedure that the cafculator 
goes through, when executing an expression, is presented. By being able to predict the 
order of execution in the calculator, you will be capable of keying in quite complex 
expressions. Here is the expression: ; 


4+6/2*(3+7) 


1. First, the operation inside the parentheses is evaluated, thus reducing the expression 


to: 
4+6/2*10 


2. Then the calculator looks for the symboi with the highest precedence; since both / 
and * have the same precedence, the calculator evaluates these two operations from 


left to right: 
4+3+*10 
4+30 


3. Finally, the addition (having the lowest precedence) is performed; the result ts then 
displayed in whatever format was previously specified. {n standard notation it would 


appear as: 
: 0 


Fortunately, when the EXECUTE key is pressed, the expression is evaluated considerably 
faster than the previous explanation might imply. Here’s an expression that is somewhat 


more complex: 


2*313+4 + ((5—3)/2+1) 


1. Taken step-by-step, this equation also is easily simplified; first, the expression in the 
most deeply nested parentheses, (5—3), is evaluated: 


2*313+4+(2/2+1) 


2. Then the expression in the remaining parentheses is simplified, and since division is 
above addition in the hierarchy, it is performed first: 


2*343+4*(1+1) 


3. These parentheses are then totally eliminated: 
2*373+4*2 


4. Now the operation with the highest precedence in the hierarchy, exponentiation, is 
performed; this reduces the expression to: 
2*27+4*2 


5, The two multiplication operations can then be evaluated: 
544+8 


6. So if the original expression is keyed in and the EXECUTE key is pressed, the result 
will appear on the display; in standard notation it will appear as: 


\} 


os 
[at 


NOTE 


Using parentheses for ‘implied’ multiplication is not allowed; hence, 
4(5—2) must appear as 4*(5—2). 
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{continued) 





An extremely useful key, when performing arithmetic operations, is the RESULT key. It 
has two specific applications: 


@ It can be used to display the numerical value of the last arithmetic statement that 
was executed. Just press: 


ee) 


@ it can be pressed during arithmetic operations, allowing you to use the result of 
the last calculation in the current expression. For example, by executing 3+4, 7 is 
displayed; then by pressing: 


QOWE 





The previous result of 7 was divided into 35, leaving a current result of 5. Now 


—ORE@8 
}) = 


The previous result (this time, 5) was added twice to the number 6. 





Often it is convenient to assign values to letters and then use these letters in expressions. 
In programs a letter can have its value constantly updated — hence, the term ‘variable’. In 
some cases a letter (variable) is used as an intermediate storage device; for instance, to 
keep the current summation of a group of numbers being added together. Other times, a 
variable in a particular formula may have several different values inserted into the 
formula to determine what effect these values have on the result. A letter can also be 
used for convenience; just as 7 is used to designate the value 3.14159265. .., an equally 
cumbersome number that you are using over and over can be designated by a letter. 


SIMPLE VARIABLES Or 


On the Modet 30 the following simple variables are allowed: 


@ Any letter — from A through Z. 
@ Any letter immediately followed by a digit — from @ through 9. 








ee er 
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For instance, acceptable simple variables are: B3, G, H®, M, MQ, Y. 
In all, 286 simple variables are allowed. 


In either the calculator or programming mode?, simple variables can be assigned values. 
Below, two variables are assigned values. Press: 


O90G!|] « COoG!}| 


In the assignment statement, the variable name appears first, followed by the equals sign, 
and then the value assigned to the variable. 


The variables A3 and B now are assigned the values 72 and 12, respectively. if we press 
the keys shown below and then press the EXECUTE key, in standard notation the 
following displays will appear: 


O80® C1 
aO® 0 
E009 Cap 


in these examples, the variable names are keyed into the arithmetic expressions and when 
the expressions are executed, the previously assigned values of the variables are used. So 
the first example is really just 72/12. 


Jeente 


4 


("= 


Variables can be reassigned values, either tndirectly or directly; for instance, to reassian B 


equal to 13, press either: 
G8Q000||)« aaa!) 


Then in any additional arithmetic expression, B is equa! to 13. 


PAcCOMmnAMm 





ARRAY VARIABLES 


Another type of variable is the array variable. To use array variables in the calculator 
mode, you must ‘initialize’ the calculator as discussed on page 4-14. Arrays become quite 
useful in the programming mode, especially when manipulating matrices. Array variabies 
can be either one or two dimensional; for instance: 


@ A(3) is a one-dimensional array, containing up to three specific items — A(t), 
A(2), and A(3); 

@ A(3,3) is a two-dimensional array, containing up to nine specific items — A(1,1), 
A(1,2), A(1,3), A(2,1), A(2,2), A(2,3), A(3,1}, A(3,2), A(3,3). 


(continued) 


+ The ‘calculator mode’ refers to non-programming operations wherras the ‘programming mode’ refers to programming 
operations. 
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(continued) 


On the Mode! 30 the following array variables are allowed: 


@ Any letter — from A through Z — followed by 


@ Either one or two numbers enclosed within parentheses (where 256 is the 
maximum size of either number}. 


When two numbers are enclosed within the parentheses, they must be separated by 
commas. 


Arrays are discussed more completely on page 3-36. 


_.—»_—+ EDITING IN CALCULATOR MODE <-> 


In the ‘calculator mode’ (that is, for non-programming operations), several editing keys 
are available. But before these keys are discussed, a brief introduction to the operating 
characteristics of the display is needed. 


The calculator, by necessity, keeps track of where it is located on the display with a 
mechanism, which we will refer to as a ‘pointer’. The pointer determines the location of 
the next character to be keyed in. 


During normal keyboard operations, with characters being keyed into the display from 
left to right, the pointer isn’t visible to the user. But, when the normal left to right 
sequence is altered, the pointer becomes visible. For, when the pointer is located at a 
previously keyed-in character, the character space flashes alternately with the character 
that’s there. 


The editing keys are as follows: 


@ (=<) which moves the pointer one character space to the left each time it’s pressed 
(until the leftmost portion of the display is accessed). 


e which moves the visible pointer one character space to the right each time it’s 
pressed (until the pointer becomes invisible}. 


e which opens up a character space immediately to the left of the visible 
pointer. 


which deletes the character space where the visible pointer is located 
e {mse} 
(SHIFT must be held down when JNSERT is pressed). 


Each of these keys, when held down for about two seconds, will rapidly repeat its 
operation. 


Here’s an example using these editing keys: 


Q@QOOOEODO® 


Now let’s add the two quantities: —1234 
+56789 


Press the keys: 














SOARED. 0 MN nae aM el er 


So we have to add a minus sign in front of the 1, delete one of the 3‘s and put a plus 
sign in front of the 5. 


a) 


b) 


c) 


d) 


e) 


First let’s jocate the pointer at the leftmost character space. Press “#cxi and keep it 
held down until the pointer is located at the 1. (Since the pointer cannot move 
past this location, it must stop there.) 


Now press “sa. A character space opens up to the left of the 1. The minus sign 
can then be keyed in. 





Now press = twice. This locates the pointer at the first 3, which can now be 
deleted by pressing the keys — SHIFT INSERT. This deletes both the 3 and the 
character space. (With the pointer located at the first 3, the space bar could have 
been pressed to delete the 3; however, the blank character space would have 
remained.) 





The pointer is now located at the remaining 3. To put a plus sign between the 4 
and 5, it is necessary to press == twice; this locates the pointer at the 5. Then 
press =), A space is opened up to the left of the 5. The plus sign can then be keyed 
in. 





\3 
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In the calculator mode, the following keys also can be used: 


which, for displays of greater than 32 characters, allows you to review the 


beginning of the display. 


© C=) which, for displays of greater than 32 characters, allows you to review the end 


@ (reu) 


of the display. 


executed. 


@ @&@ which allows you to keep a printed record of whatever you're doing. 


@ gaxat which erases memory. 


age ates ae ma en HE SEE EP Ne: a NE = REP me: Tm Ferner ee | cemeciremp helen ae root 


In the following paragraphs, these keys are discussed in detail. 


(continued} 


+ The arrow shovs the position of the blinking indicator. 


which allows you to review the previous expression or key sequence that was 
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{continued} 
sp ee SS 
With these two keys, an input of up to 80 characters can be viewed on the 32-character 
display. 
Key in the following expression, which repeats each numerical digit eight times: 


11111111422222222+33333333+44444444+55555555+ 66666666+77777777+88888888+ 99999999 
NOTE 1 NOTE 2 


Note 1: 


Notice that when the fifth ‘4’ is keyed in, the 32-character display has been filled. Each 
additional character then pushes the display region one character space to the left, thus 
eliminating the leftmost character from the display. 


Note 2: 


Notice also that when the last ‘+’ sign is keyed in, the calculator makes a soft beeping 
sound, informing the user that 72 of the allowable 80 characters have been keyed in. 


After the last ‘9’ has been keyed in, the display looks like this: 





— q 
a oe ee ies a 


To view any other portion of the expression, hold 27 (the right arrow) down for a few 
seconds; the display region is rapidly pushed to the right. When the portion of the 
display that you want to see is visible, just release this key. If you are at the end of the 
display and you want to view the beginning, just hold C2— down for about five seconds 
and the beginning of the display should be visible; it doesn’t matter if you hold the key 
down longer because once the leftmost 32 characters are displayed, (25 has no more 
effect. 


To view the end of the display, you can use {the left arrow). It performs the reverse 
operation of the right arrow. When C=_ is pressed, the display region is pushed to the 
left. 


Of course, either key can be used to shift the display region one character space at a 
time. So to push the display region three spaces to the right, just press (5 three times. 


In all cases after the eightieth character has been keyed in, it is impossible to input an 
eighty-first character. But the expression can be executed at any time; in this case, the 


result is: ‘ 


4 





x —<————_— i 


When the RECALL key is pressed, the last thing that was executed by the calculator is 
recalled to the display. The original expression can then be viewed, edited and 
re-executed if necessary. For example, press: 


OQOHOOCOOSOO8U 
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if you execute this expression, the display will read: 





A quick check of the error codes shows that a right parenthesis is missing from the 
expression. If au) is then pressed, the original expression is recalled to the display: 





Then the corrected expression can be executed: 


5 \) 


a ee ee 


The PRT ALL (Print-All) key is used to obtain a printed record of your operations. 


in the calculator mode with print-all in effect, everything in the display that is executed 
is recorded on the printer. The result of the execution is also printed. 


Pressing @4i either establishes or cancels print-all: 
@ if ON appears in the display, print-all is established. 
@ if OFF appears, print-all is cancelled. 
By pressing a second time, the ON or OFF designation is reversed. 

: If the printer isn’t connected to the calculator, be sure print-all is OFF; otherwise, the 
display will ‘blank out’ when the EXECUTE key is pressed (if this occurs, hold the STOP 
key down until STOP appears on the display to regain control of the calculator). Printer 
plug-in instructions are located in Appendix A of this book. 


Here are some examples with print-all ON: 


Keyboard Entries Printouts 
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(continued) 


<=. ee 


Different portions of memory can be erased with the following variations of the 


SCRATCH command: 


[programs on Special Function keys (see Chapter 6) are not affected]. In 


erases all variables from memory and program lines from mainline memory 


many cases, this command effectively erases ail the memory. 


i 
©) 
=) 


=(0) 


mac amam 


=(0 


RACOMm mM 


erases ait of memory; it is the same as turning the calculator off and then 
on again. 


erases the values of all variables. 


erases all Special Function keys. 


erases the particular Special Function key that is pressed. 


~~~ FUNCTIONS ~~ oO 


The following paragra 


Model 30. 


phs describe the mathematical and trigonometric functions in the 


MATHEMATICAL FUNCTIONS a TTT 


The following mathematical functions can be executed: 


ABS (expression) t 
EXP (expression) 


INT (expression} 
LGT (expression) 
LOG (expression) 


RND (expression) 


determines the absolute value of the expression; 

raises the constant, e, to the power of the computed 
expression; 

gives the expression an integer vatue < the value of the 
expression; 

determines the logarithm of a positively valued expression 
to the base 10; 

determines the logarithm of a positively valued expression 
to the base ’e’; 

gives a random number between @ and 1; the expression is 
a dummy argument; 


+ Throughout this text, the word ‘expression’ includes constants [like 43.2), variables (like A), expressions {like 
43.2*A), and other functions (like INT A}. 














SGN (expression) returns a 1 if the expression is greater than zero, returns a 
@ if the expression equals zero, or returns a —1 if the 
expression is less than zero; 


SOR (expression) computes the square root of a positively valued expression. 


In general, it is wise to separate the expression by parentheses although parentheses are 
optional if the expression is either a positive constant, a variable, or another function. 


As can be seen by the examples to follow, most of these functions are relatively easy to 
use; however, the RND function warrants the additional explanation given it. 


In the standard mode, execute these key sequences: 


-OHOOOOOOO Cs) 


which gives a positive value to the expression. 


Gl 


which is the value of the constant, e, raised to the first power. 


- OWOOOOOOHO® : 
Cas 


| OODOOO80088 ' 
6 


The integer value returned must be less than or equal to the result of the 
expression. So for a result of 25.2, 25 is returned; whereas for a result of —25.2, 


26 is returned. 


BOO GG 
OOO 


LGT is used for determining logarithms to the base 10, whereas LOG is used for 
determining logarithms to the base ‘e’ (natural logs). The following key sequences 
show how the result of an expression can be determined if logarithms are used. 





r 
(Ts 


Here’s a practical example. Suppose we wish to solve for X, where 
X=144111/121108 _ This equation cannot be solved by using regular mathematics, 
since the range of the calculator would be exceeded. But this equation can be 
solved by using logarithms and their mathematical rules. Using Y=log,, X, key in 


y and execute: 
Y=111*LGT144—108*LGT121 
Then to solve for X, execute: 


X=10TY 
(continued) 
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(continued) 
ie Whereas using Y=log, X, key in and execute: 


Y=111*L0G144—108*LOG121 
Then to solve for X, execute: 
X=EXPY 








- HOOF) 


A random number between @ and 1 is displayed each time RND x is executed. 


Often it is useful to have random numbers appear as integers that are within a 
certain range. For instance, random integers from @ through 999 are output if 
you execute: 


| VOOOMNMOGHOOOOO 


Now each time this expression is executed (this is easily accomplished if you press 
— RECALL EXECUTE}, a new random number is generated. 





Each time the calculator is turned on, the random number generator uses the 
same ‘seed’ (that is, the number upon which the sequencing is based). This causes 
the sequence of numbers to be the same each time the RND function is initially 
used. But you can avoid the repetition if you put in your own ‘seed’. This iS 
accomplished by executing: 


MHMOOOMQ 


The negative sign causes the seed to be changed while the number input for ‘n’ 
becomes the new seed. 


Some seeds do make better random number generators than others. To obtain a 


good seed, n should be a number between @ and 1; the more digits the number 
has, the better — up to 11; and it is often preferable to make the last digit either 


a 1, 3, 7, or 9. 


Here’s an example of a good seed. Execute: 


AMOOQOOOOUOOOOOOO 


Now that the seed is generated, random numbers can once again be obtained by 
the method previously discussed. 


The seed that the Model 30 itself uses is: (2—a/2). 





7 where ‘X" can be any positive number. The positive number used has absolutely no effect on the random number 


that is generated. 
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natural logarithms (LOG)... 2-14, 2-15 — 2-16 
NEXT statement (with FOR} . . . 3-12 — 3-16 
non-recoverable errors . ......-.. ET RAD (radians) 





NORMAL key . ......- 2+ « - = «410 command < ¢ «4 #4 % ee ee ee oY 
NOT operator ..... . 1 © «© « « « 2 2°20 statement MM iG ops Cte ti way Gd? ee gh 





~>-—~<_~<>-_-<> >_> _+>_o 2° 2 7. 72 ¢ <-e 


random number (RND) function 
range, calculating 


READ (and DATA} statement’ 


with RESTORE 


RECALL key 


record (see STOR E) 


recoverable errors 
relational operators 
REM (remark) statement 


REN {renumber) command 
repetition of operations 
RESTORE statement 

with READ and DATA 


RESULT key 


RETURN statement 


with DEF FN 
with GOSUB 


REWIND command 


RND (random number) fanetion 


ROM’s 
description 
extended I/O 
installing 
matrix . . 
ordering . 
plotter . . 
strings . . 
terminal 

rounding 

RUN key .. 


SCRATCH key 


SEC (secure) command 


service contracts 


SGN (sign) function 
significant digits (accuracy) 


simple variables 


. 


simultaneous calculations 
SIN (sine) function 


spacing 


special function eve 


as functions 
as programs 
as text. 
entering =. 
exiting 
overlays 


. 


. 


split-precision data 


SOR (square root) function 


. 


. 


* - « « 


* 





E-1 
. 2-19 
3-11 
4-5 
ae ae | 
. 3-20 
~. . 28 


3-33 — 3-35 
3-30, 3-31 
. . .917 
2-14, 2-16 


sve a Cl 
~ « « GS 
C-1 — C-2 
C-3 
- . . C2 
.. . C3 
. 5-18, C4 
C4 


ce tue SOB 
. 4-1, 4-2 


64 
6-2 
6-1 
6-1 
ecg ao Oe? 
. » -d38 
2-15, 2-17 


STANDARD statement uy 
STD (standard) key ae 
STEP Key-acp os - a. a ee ws 
STOP 

command yee 2 

statement de 3 Fee “sion i A oe 
STORE command Sis tae Sat 
STORE DATA command 
STORE KEY command 


string variables ROM .... 
“ summary, manual . . .. . - 
symbols 
Ae Se ee ee ee ee 
tT . ot cs! go oS : 
? 


. « « « . . . . ’ . - 


syntaxes 
BASIC programming .. . 
cassette a ie oe he 


tabbed index by chapter .. .- 
table of contents ...... 
TAN (tangent) function 

tape (see cassette} 


terminai ROM ....... 
TLIST command ...... 
TRACE key .... oh 
trigonometric functions .. . 
turn-on procedure 

general . . - - . - - ss 


initial calculator . 3 
initial printer {9866A) 





variables 
array we ee ee 2 2G 
SIMDIC:: 6.4% wae @. ee! Be 
WAIT statement .. .- 
WRITE command Sie da We 
WRITE statement ee ee 
with FORMAT Sr oar \ hg Wado oe 


* - 


. . 921, 6-7 
. 5-18, C4 
ee eee | 
. . » 42 
i is, oe 
. 2-19 
2-17 
~~... 38 
3-44 — 3-46 
. . 54, 5-25 


: so gt 
: 2-47, 2-18 


. C4 
- « .923 
. . -4-10 
2-17 — 2-18 


Std sah te NO 
.. . Ad 
- ADS 


2-10, 3-36 — 3-37 


28 


wee oT? 
oe me 2222 
. 3-21, 3-28 
3-22 ~ 3-27 
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UNITED STATES 


ALABAMA 

P.0. Bou 4207 

2003 Byrd Spring Road S.W. 
Wantstiile 353802 

Tel: (20$) 681-4591 

TW: 810-726-2204 


ARIZONA 

2336 E. Magnolia St. 
Pheenix 65035 

Tet: (602) 244-1363 
TWE: 910-951-1336 


S73? East Sroadway 
Teesen 85711 

Tel: (602) 298-2313 
TWH: 910-952-1162 


CALIFORNIA 

1430 East Orangethorpe Ave. 
Feltertan 92631 

Tel: (714) 870-1600 

TWX: 910-592-1288 


3939 Lankershim Boulevard 
Recta Hallyweed 91604 
Tel: (213) 877-2282 

WR: 910-499-2170 


6305 Arizona Piace 
Les Angeles $0045 
Tel: (213) 649-2511 
TWX: 910-378-4148 


1102 Embarcadero Road 
Pale Alte $4303 

Tel: (415) 327-6500 
TWX: 910-373-1280 


2220 Watt Ave. 

Sactamento 95825 
Tel: (916) 482-1463 
TWK: 910-367-2092 


9606 Aero Drive 
P.O. Box 23333 
Soe Diege $2123 
Tei: (714) 279-3200 
FW: 930-335-2000 


COLORADO 

7965 East Prentice 
Engieweed 20110 
Tel: (303) 771-3455 
TWX: 910-935-0705 


CONNECTICUT 
12 Lutiar Ofive 
Mew Hares 06525 
Tei: (203) 389-6991 
TWR: 710-465-2029 


FLORIDA 

PO, Bor 24210 

2806 W. Oakland Park Bid. 
Ft tamderdale 33307 

Tel: (30) 731-2020 

TWX: §10-955-4099 


P.O. Bor 13910 

6177 Lake Elienor Or. 
Ortanée, 32809 

Tel: (305) &$9-2900 
TWH: 810-850-0113 


GEORGIA 

P.O. Box 78234 

450 Jaterstate Narte 
Atianta 30328 

Tet: (404) 436-6181 
TWX: 310-766-4890 


HAWAILE 

2875 So. Ming Street 
Keaslalw 96814 

Tel. (808) 955-4455 


ILLINOIS. 

$500 Howard Street 
Shotle GOO7S 

Tel: (332) 677-0400 
TWX: 910-223-3613 


INDIANA 

1839 Meadows Drive 
lndiamapalis 46205 
Tel: (317) 546-4891 
TWE: 810-341-3263 


LOUISIANA 

Ff. O. Bor 840 

3239 Widiams Soulevard 
Kenner 70062 

Tel: (504) 721-6201 
TWE: 810-955-5524 


ELECTRONIC 


SALES & SERVICE OFFICES 


MARYLAND 

6707 Whitestone Road 
Baltimere 212¢7 

Tel: (301) 344-5400 
FWX: 716-862-9157 


P.O. Box 1648 

2 Choke Cherry Road 
Rocktilie 2CS50 
Tel; (OL; $48-6370 
TWE: 710-525: KE 


MASSACHUSETTS 
32 Hartweil Ave. 
Lexingtaa 02173 
Tel: ‘617: 861-2960 
TW: 710-326-6904 


MICHIGAN 

23855 Research Drive 
Farmingtes 48024 
Tel; (313) 476-6400 
TWX: 81242-2900 


MINNESOTA 

2459 University Avenue 
St. Paci 55114 

Tel: (612) 645-9461 
TWH: 910-563-3734 


MISSOURI 

11331 Cotarado Ave. 
Wansas City 641397 
Tel: (826) 763-8000 
TWX: 910-771-2087 


148 Weldon Pathway 
Maryland Heights 63043 
Tet: (314) 567-1455 
TWX: 910-764-0830 


*NEVADA 
Las Vegas 
Tel: (702) 382-5777 


NEW JERSEY 

W. 120 Century Road 
Paramus 07652 

Tel: {201) 265-5000 
TWX: 710-930-4952 


1060 N. Kings Highway 
Cherry Hii! 08034 

Tel: (609) 667-4000 
TWEE: 710-892-4945 


NEW MEXICO 

P.O. Box 8366 

Station C 

6401 Lomas Boulevard I.E. 
Afiaquergoe 87108 

Tel: (SG5° 255-3713 

TWX: 910-589-1665 


156 Wyatt Drive 
Lag Cruces 88002 
Tel: (505) $26-2485 
TWX: 910-983-0550 


NEW YORK 

6 Automation Lane 
Computer Park 
Afbany 12205 

Tet: (S18) 458-1550 
TWH: 710-441-8270 


1219 Camoviile Road 
Eadicett 13760 

Tet: (607} 784-0050 
TWH: 510-252-0890 


Wee York City 

Manhattan, Bronx 

Contact Paramus, NJ Office 
Fel: (201) 265-5000 
Brooktyn, Queens, Richmond 
Contact Woodbury, NY Office 
Tel: ($16) 9210300 


&2 Washington Street 
Poughkeepsie 12601 
Tel: (914) 454-7330 
TWX: $10-248-0012 


39 Saginaw Drive 
Rochester 14623 
Tel: (716) 473-9500 
TWH: $10-253-5981 


$458 East Molloy Road 
Syracuse 13211 

Tel: (318) 454.2485 
TWX: 710-541-0482 


1 Crossways Park’ st 
Woodtury 11797 

Tel: ($16) 921-0300 
TWH, $10-221-2168 


NORTH CAROLINA 
P.O. Bor S18 

1923 Narth Main Street 
High Pelet 27262 

Tel: 919) 885-8101 
TWX: 510-926-1516 


Onto 

25575 Center Ridge Road 
Cleveland 44145 

Tel: (236) 835-0300 
TWH: 810-427-9129 


330 Progress Rd. 
Daytes 45.49 

fel: (513° 855-8202 
TWK: 810-459-1925 


1120 Morse Road 
Celgmbus 43229 
Tel: (634) 886-1300 


OKLAHOMA 

P.O. Box 32008 
Ohfahama City 73132 
Tel: (2053 721-0200 
TWH: 910-830-6862 


OREGON 

17890 SW Boones Ferry Road 
Tualatin 97962 

Tel: (5035 620-3350 

TWX: 910-467-8714 


PENNSYLVANIA 

2500 Moss Site Boulevard 
Monroeville 215146 

Tel; ($12) 271-0728 

TWX: 710-797-3650 


1021 8th Avenue 

King of Prussia industrial Park 
King af Prossia 19406 

Tel: (21S) 265-7000 

TWH; §10-660-2570 


RHODE ISLAND 
873 Waterman Are. 
East Providence C2914 
Tel: (401) 434-5535 
TWH: 710-381-7573 


*TENNESSEE 
Memphis 
Tel; (901) 274-7472 


TEXAS 

9.0. Bcx 1270 

201 £. Arapaho Rd. 
Richwdsen 7S28) 
Te: 224 2324101 
TWK: $iGBS 74723 
P.O. Bon 27429 
6300 Westpark Drive 
Suite 159 

Haustes 77027 

Tel; (723) 781-6000 
TWR: 910-881-2545 


231 Gilly Mitchell Road 
Sam Antonie 78226 
Tei: (512° 434-4171 
TWH: 910-871-1170 


UTAH 

2890 South Main Street 
Salt Lake City #4115 
Fal: (SOR) 487-0715 
TWH: 910-925-$541 


VIRGINIA 

P.O. Sox 6514 

2111 Srencer Road 
Richmead 23230 
Tel. 857) 285-3431 
TWK: 710-556-0157 
WASHINGTON 
Beifefie'd Office Pr. 
1203+ 115th SE 
Gellevee S8205 

Tel; .20)° 254-3971 
TW: 910-443-203 


“WEST VIRGINIA 
Chariesten 
Tel: 3) HS-1640 


WISCONSIN 

$31 W. Beloit Road 
Suite 117 
Milwaukee 53227 
Tel: (414; 541-0550 


FOR U.S. AREAS NOT 
LISTED: 

Contact the regiona! office near- 
est you: Atlanta, Georgia... 
North Holiyaocd, California... 
Paramus, New Jersey... Skokie, 
Hlingis. Their complete ad- 
dresses are listed above. 
*Service Only 


i — 


CANADA 


ALBERTA 

Hewlett-Packard (Canada) Ltd. 
11748 Kingsway Ave. 
Edenton 

Tel: (403) 452-3676 

TWX: 610-831-2431 


BRITISH COLUMBIA 
Hewlett-Packard (Canaca} Ltd. 
8608 Canada Way 

North Burnaby 2 

Tel: (604) 433-8213 

TWE: 610-922-5059 


MANITOBA 

Hewlett-Packard (Canadai Ltd. 
513 Century St. 

Winnipeg 

Yel: (204) 786-7582 

TWH: 610-671-3531 


NOVA SCOTIA 
Hewlett-Packard (Canada} Ltd. 
2745 Outch Village Ad. 

Suite 210 

Hatifax 

Tel: (902) 455-0511 

TWX: 610-271-4482 


ONTARIO 

Hewlett-Packard (Canada) Ltd. 
£785 Woadeard Dr. 

Ottawa 3 

Tel: (613) 265-6180, 255-6530 
TWH: 610-562-8968 


Hewlett-Packard (Canada) Ltd. 
50 Galaxy Btvd. 

Rexdais 

Tel: (416) 677-9621 

TWK: 610-492-4246 


QUEBEC 

Hewlett-Packard (Canada) Ltd. 
275 Hymus Boulevard 

Points Claire 

Tel: {524° 697-6232 

TWX: 610-422-3022 

Tefex: 01-20607 


FOR CANADIAN AREAS NOT 
LISTED: 

Contact Hewlett-Packard (Can- 
ada) Ltd. in Pointe Claire, at 
the complete address listed 
above. 


a 


CENTRAL AND SOUTH AMERICA 


ARGENTINA 
Hewlett-Packard Argentina 
SAC.e.1 

Lavatle 1171-37 

Gpengs Aires 

Tel: 35-0436, 35-0627, 35-0341 
Tefex: 012-1009 

Cable: HEWPACK ARG 


BOLIVIA 

Stambuk & Mark (Bolivia) LTOA. 
Av. Mariscal, Santa Cruz 13-2 
la Paz 

Tel: 40626, 53163, 52421 
Telex: 3560014 

Cable: BUKMAR 


BRAZIL 

Hewlett-Packard Do Brasil 
LEC. Ltdéa. 

Rua Frei Caneca 1119 
9130?-Sae Paulo. SP 

Fel: 288-7111, 287-5858 
Telex: 309151 ‘2/3 

Cable: HEWPACK Sao Pauto 


Hewlett-Packard Do Brasil 
LE. lide. 

Praca Oom Feliciano. 78 
900C0-Perte Alegre-RS 

Rio Grande do Sul RS’ Brasil 
Tet, 25-8479 

Cable: HEWPACK Porto Alegre 


Hewlett-Packard Do Brasil 
LEC. Ltda. 

Rua ta Matriz, 29 

20000-Rie de Janeire-CS 

Tet: 266-2643 

Telex; 210079 HEWPACK 

Cabte: HEWPACK Rio de Janeiro 


CHILE 

Héctor Calcagni y Cia, Lita. 
Casina 16.475 

Santiag@ 

Tel: 423 96 

Cable: CALCAGNI Santiago 


COLOMBIA 
Instrumentacién 


Henrik A Langebaek & Mier 5.8. 


Carrera 7 No, 48-59 
Anartado Aéreo 6287 
Bogatz, 1 DE. 

Tel, 59-78-08, 45-55-36 
Cable: AARIS Bogota 
Jetea: 4550G1NSTCO 





COSTA RICA 

Lic. Alfrede Gallegos Gurdiéa 
Apartado 19159 

San José 

Tet: 23-85-23 

Cable: GALGUR San tosé 


ECUADOR 

Laboratorios de Radio-Ingenieria 
Calle Guayacuil 1256 

Post Office Bor 3199 

Quits 

Tel: 212-536; 219-185 

Cable: HORYATH Quito 


EL SALVADOR 

Electronic Associates 
Acartata Pssta! 1£22 

Centra Comerciat Gigante 

San Salvader, E: Saisatcr CA. 
Paseo Esta’cn 4553-3" Piso 
Tel: 234269, 23-32-37 
Cable: ELECAS 


GUATEMALA 

tPESA 

Sa via 2-01, Zona d 
Guatemala City 

Tel: €3-5-27 & 547-85 
Telex: 4122 TELTRO GU 


MEXICO 

Hewtett-Packard Mexicana, 
Sa.ce Cy, 

Torres Ataid Mo. 21. 11° Piso 
Col. cal vace 

Metico 12, OF. 

Tel: 53-42-32 

Teles G17-74-307 


NICARAGUA 

Roberto Teran G. 
Apartado Postal 689 
Edificio Terén 

Managua 

Tel; 3451, 3552 

Cable: ROTERAN Managua 


PANAMA 

Electrinico Baiboa, S.A 

P.O. Box 4229 

Ave. Marval Espinosa No. 13-50 
aitg. Alina 

Panama City 

Tel: 232833 

Telex: 3481103, Cuninda, 
Canat Zore 

Cable: ELECTRON Panama City 





PARAGUAY 

Z. 1. Melamed S.RL. 

Division: Aparatos y Equipos 
Meditos 

Division: Aparatos y Equipos 
Scientifices y de 
Ineestigecian 

P.0. Box 675 

Chite, 442, Edificia Victoria 

Asuncion 

Tel: $-S069, 4.6272 

Cable; RAMEL 


PERU 

Compafua Electro Médica S.A. 
Ave. Enrique Canayai 312 

San Isidro 

Casilfa 1030 

Lima 

Tel: 22-3900 

Cable: ELMED Lima 


FUERTO RICO 

San Juan Electronics, Ine. 
P.O. Box S167 

Ponce ¢e# Leon 154 

Pda. 3-PTA de Tierra 

San Juan CCSO6 

Tal: 18993 725-3342, 722-3342 
Cable: SATRON'CS San Juan 
Telex: SATRIN 3450 332 


URUGUAY 

Pab!o Ferranco S.A. 
Comercial e Industrial 
Avenida Miatia 2977 
Casitla de Correo 370 
Mootesvidee 

Tel: 49-3102 

Cable: RADIUM Montevidea 





VENEZUELA 
Hew'ett-Packard de Venezuela 
C.A. 

Apartads $7933 

Edifizia Segre 

Tercera Transversal 

Los Puc#s arte 
Caracas 1? 

Tet: 35-00-11 

Telex: 21145 HEAPACK 
Cabie. HEWPACK Caracas 


FOR AREAS NOT LISTEO, 


CONTACT: 
Hewiett-Pachard 
Inter-Amerizas 

3209 ww Ast. 

Pala Alte, California $4304 
Tel: (426 432-1501 

TWE: $10-373-2257 
Cable: KEWPATA Pao Ato 
Telex: 634-8300, 034-8493 
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7 | APPENDIX F 
PRINTER OPERATING PROCEDURES 


This appendix discusses operation of the primary printers described in Appendix A. 


~>—>—_-e—e—> PRINTER SELECT CODE --—ooo 


Any device connected to the calculator requires a ‘select code’ so that the calcufator can 
distinguish it from all other devices. The select code on a primary printer must be set to 
‘15’. The 9866A Printer (Option 30), the interface for the 9861A Output Typewriter, 
and the 11205A Serial 1/O Interface used with the teleprinter, are all preset, at the 
factory, to select code 15. But any of the printers can be used as a secondary printer 
with the Model 30, too, if the select code of the supplied interface card is changed. (To 
use the 9866A Printer as a secondary printer, the -hp- 09866-61610 interface card must 
be purchased.) 


~~~. ———~ THE 9866A PRINTER <<? ooo 


Of the printers discussed in Appendix A, the 9866A Printer is easiest to operate because 
it has no mechanical controts, other than the PAPER key, which is used to manually 
advance paper. Once the printer has been connected to the calculator, loaded with paper, 
and turned on (see Appendix A), it is controlled by the calculator. 


The statements and commands used to contro! the printer are fully described in the 
appropriate places in this book. Table F-1 lists each operation and tells you in which 
chapter to look for its explanation. You may also wish to refer to ‘Printer Character 
Codes’, tater in this appendix; however, it is recommended that you become proficient in 
the use of the WRITE and FORMAT statements before doing so. 


~e—e—> THE 9861A OUTPUT TYPEWRITER <-oo 


Before the typewriter can be controlled from the calculator, its controls must be properly 
set. Necessary control settings on the typewriter consist of: 
@ The desired line-spacing; 
@ The margins, to sult your paper; 
® Black ribbon (red or black ribbon can be set from the calculator, but only if the 
typewriter is set to black ribbon): 
@ The ‘shift’ key being unlocked (the calculator will automatically shift the 
typewriter keyboard, if it needs to, to obtain a particular character); 
@ The impact requlator being set for the desired copy hardness; 
@ Select code 15 being set. 


Even though the typewriter is connected to the calculator, the keyboard on the 

typewriter is completely operational. So, if you wish, you can clear and set tabs, 

carriage-return, or perform any other ‘initializing’ operations; or you can type directly 
(Continued) 


~ 


re, Se PEER OSH LIE PY RA Et mae ne eI S * . iG ole Ant wy Sie aca 
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~—>—> > THE 9861A OUTPUT TYPEWRITER —-—>o— > 


(Continued) 


from the typewriter keyboard. All of these operations can also be controlled from the 
calculator. 


The statements and commands used to control the typewriter (which are the same as 
those used to control the 9866A Printer) are fully described in the appropriate places in 
this book (see Table F-1). The section, ‘Printer Character Codes’, later in this appendix 
gives the codes that are needed to perform additional contro! functions, such as clearing 
and setting tabs, and changing from black to red ribbon. 


The calculator automatically shifts the typewriter keyboard if it needs to de so to print a 
particular character. So, when you are typing characters for the typewriter on the 
calculator keyboard, you do not need to know whether the typewriter keyboard is to be 
shifted or not; but you do need to know if the calculator keyboard has to be shifted {as 
it does, for example, when you wish to print a lower case letter). 


Example 


Following is a printout, from a typewriter, and the program which produced it. The 
program demonstrates some of the flexibility that you have in formatting the typewriter 
output. This program relies heavily on the use of the character codes, which are described at 
the end of this appendix. Therefore it is recommended that you become proficient with the 
typewriter and, in particular, with the WRITE and FORMAT statements, before you spend 
any time analyzing this program. 


The 9861A Typewriter can be controlled by the 9830 


Calculator. The ribbon can be changed to red and 
back to black. 


Physical tabs can be set, 

and the tab key can be operated. 
The following special characters 
can be typed: 


ee Oe | 


Also you can cause the typewriter to 
skip lines, backsvace, and clear tabs. 


co 





, 10 
20 
30 
40 


F-3 


FORMAT 153 
FIXED 0 
X=9830 
PRINT TAB6O; 


50 WRITE (15,10)11,7 

60 PRINT "The 9861A Typewriter can be controlled by the";X 
70 PRINT "Calculator. The ribbon can be "; 

80 WRITE (15,10)6"changed to red "7"and" 

90 PRINT "back to black." 

100 PRINT 


110 PRINT TAB18; 
120 WRITE (15,10)1,"Physical tabs can be set," 
430 WRITE (15,10)9"and the tab key can be operated." 
440 WRITE (15,10)9"The following special characters " 
150 WRITE (15,10)9"can be typed:" 
160 PRINT TABI8; 
| 170 WRITE (15,10)12; 
) s 180 PRINT TAB30; 
190 WRITE (15,10)1;91,10,8,93,10,8,123 
200 WRITE (15,10)9,125,10,8, 126, 10,8, 34, 10,8, 96 
240 WRITE (15,10)11,10,10,"Also you can "; 
220 PRINT “cause the typewriter to" 
230 WRITE (15,10)"skip lines, backspace"; 
240 FOR I=i TO 9 
250 WRITE (15,10)83;9538;3 
260 NEXT I 
270 PRINT " » and clear tabs." 
280 END 


Table F-1. Printer Operations 


COMMAND 
REFER TO 
or DESCRIPTION CHAPTER... 


STATEMENT 


Standard printing statement 
Enables more flexible format for printing 


Lists program lines 

Prints each operation 

Prints tine number as line is executed 
Cancels TRACE 

Lists information from tape cassette 
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~@—e THE TELETYPE 38 ASR DATA TERMINAL -*—* 


Before the teleprinter can be controlled by the calculator, its controls must be properly set. 


On the teleprinter: 


@ Select LINE operation; 
@ Ensure that SHIFT LOCK is unlocked. 


On the interface: 


® Set select code 15 (see page F-1, Printer Select Code); 


@ Set a baud rate of 110 — the interface is preset at the factory for a baud rate of 110, so 
it will probably not need adjusting* (refer to the manual for the 11205A Serial 1/0 
Interface for complete details). 


The statements and commands used to control the teleprinter (which are the same as those 
used to control the 9866A Printer) are fully described in the appropriate places in this book 
(see Table F-1). The section ‘Printer Character Codes’, later in this appendix, gives the codes 
that are needed to perform additional control functions, such as changing ribbon color, 
form-feeding, and executing a line feed without a carrizge return (or vice versa). 


The calculator automatically shifts the teleprinter keyborrd if it needs to do so to print a 
particular character. So, when you are typing characters for the teleprinter on the calculator 
keyboard, you do not need to know whether or not the teleprinter keyboard has to be 
shifted for that character; but you do need to know if the calculator keyboard has to be 
shifted (as it does, for example, when you wish to print a lower case letter). 





Example 


Following is a printout, from a teleprinter, and the program which produced it. The 
program demonstrates some of the flexibility that you have in formatting the teleprinter 
output. This program relies heavily on the use of the character codes, which are described at 
the end of this appendix. Therefore, it is recommended that you become proficient with the 
teleprinter and, in particular, with the WRITE and FORMAT statements, before you spend 
any time analyzing this program. 


The Model 38 telepvrinter can be controlled by the 9&3ZA 
Calculator. Amone other things, the ribbon can be changec 
to red and back to black. 


The teleprinter can be made to 
tab to any position, 
as can be seen from this printout! 


The following special charecters 
can be typed: 


inter carri2ce return 


Also vou can make the t r 
ali cd. This enables you £9 


Without executins 
Underline. 


Tif necessary, it is very easy to adjust the baud rate, by means of a calibrated screwdriver-contro! on the underside of the 
interface card. Remove the card from the interface slot at the back of the calculator, and adjust the control to the desired 
setting. 
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La 


2a 
38 
4d 
5o 
6% 
78 
82 
96 
182 
11d 
12% 
132 
Lada 
15 
162 
172 
182 
19% 
eae 
212 
228 
23 
248 


) 252 
266 


2708 
282 
296 
388 
312 
326 


FORMAT i153 

X=9833 

CRINT 

PRiNT 

WRITE €15,623)"can be controlled by the” 5X 

FORMAT “The Model 35 teleprinter “,FS.2,°A” 

PRINT “Celculator. Among other things, the ribbon 


WRITE €15,18)"can de “27,51 “changed” 
WRITE (15,18)"to red and “27,52"back to black.” 
PRINT 

PRINT TABI@"The teleprinter can be made to 
PRINT TASIS" tad TAB25"to any” TA3S39" position,” 
PRINT TABI@"as can be seen from this printout!” 
PRINT : 
PRINT “The following special characters 

PRINT “can be typed:” 

PRINT TABI3;3 

WRITE €15,18)34,32,91 ,32,92,32,93,16 

PRINT TASI33 

VRITE (15,18)96,32,123,32,124,32,125,32,126 
WRITE €15,18)18"Also you can “3 

PRINT “make the teleprinter carriage return” 
WRITE €15,10)"without executing a linefeed. This 
WRITE €15,10)"enables you to°13,;83 

PRINT TAB47; 

WRITE €15,16)95,95 

WRITE €15,19)"underline. "13,63 

FOR I1=1 TO 16 

WRITE €15,10)95;3 

NEXT I 

PRINT 

«END 


F-5 


Notice in lines 80 and 90 of the program that the teleprinter requires two keys to change 
ribbon color: 


ESC 3 (codes 27, 51) selects red ribbon; 
ESC 4 {codes 27, 52) selects black ribbon. 





~>—>———> PRINTER CHARACTER CODES <-—o-oo 


Table F-2 lists the decimal codes used in WRITE statements to reference FORMAT 8 
statements (described in Chapter 3). The table lists (decimal) numbers 8 through 127 and 
gives the corresponding ASCII character (or control function) for the 9866A Printer, for the 
9861A Typewriter and for the 38 ASR teleprinter. Some of these characters and control 
) ‘ functions can be obtained only by using their decimal equivalents in WRITE (with 
FORMAT 8) statements. However, many of them can also be obtained directly from the 
calculator keyboard. An empty space opposite a decimal code in the table indicates that the 
specific printing device does not recognize that code number and that it will simply ignore 


it. 


(Continued} 
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~~~. -~e—> PRINTER CHARACTER CODES ~<-—°o> 


{Continued} 


NOTE 
If you are using any other printer, refer to its manual for its character set. 
Some manuals may give the binary or octal equivalents, rather than the decimal 
equivalents of the characters. In these cases you must convert the binary or 
octal numbers to their equivalent decimal values, because only the decimal 
numbers can be used in WRITE (with FORMAT B) statements. 





In general, you will not need the character codes for the 9866A Printer because most of Its 
characters, and all of its control functions, can be obtained from the calculator keyboard. 
When using the typewriter or the teleprinter, you will need these codes to perform 
additional control functions, such as changing from black ribbon to red ribbon, setting tabs 
{on the typewriter) and form-feeding (on the teleprinter). 


The codes for all of the teleprinter keys are included. However, the teleprinter itself does 
not respond to some of these keys, even though, as a terminal, it may transmit them. For 
example, it has a backspace key (BS, code 8) but its carriage cannot backspace. (Refer to 
the manual supplied with the teleprinter for complete details.) 


Table F-2. Printer Characters and Equivalent Decimal Codes 
Decimal 9866A 9861A 38 ASR Decimal 9866A 9861A 38 ASR 
Code Printer Typewriter | Teleprinter Code Printer Typewriter | Teleprinter 
25 EM 


TAB SET 


RED 
RIBBON 


BLACK 
RIBBON 


BACKSPACE 
TAB 


LINE FEED 


CLEAR 
ALL TABS 
TAB 
CLEAR 
CARRIAGE 


RETURN 


mtr, 


ree 
ARO YE Rae RE RE YY eR SNE OR 


Table F-2. Printer Characters and Equivalent Decimal Codes (cont’d) 


Qn Pr 8! 


. 
a0 ae 
. 


@anr~w~ViaA 
an~VvViuiA 
@anryVt A 
xranmdad 


A A A t 
B B B J 
Cc C Cc K 
D D D L 
E E E M 


an 70 79 O2Z2SB4ra e- Dron 
samme OZ. T A je—_-ro mn 
4onmO v O2SPT RK j—_rIO mn 
“oN <x S<ciHa0 amovodazZz 


<xe< ¢ 
<xeec 
<xe<cc 
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ABS {absolute value) function 


accessories list 


accuracy (significant digits) 


AND operator 


arccosine function 
aresine function . 
arctangent (ATN) function: 


arithmetic 
calculating 
hierarchy 
keys 

amay variables 

arrows 


i ee 


- > 


cy 


ASCII cliavacter codes 


assignment (LET) statement 


at ‘@’ symbol 


ATN {arctangent) function 


AUTO# key 


BACK key. 


BASIC statements 


comparisons 
discussions 
syntaxes . 


calculating range 


calculator 
cleaning 
fuses. 
grounding 


initial turn-on 


inspection 
installation 
keyboard 


power outlets 
power requirements 


- 


card reader, model 60 


cassette 


cleaning transport 


commands 


file structure 


. * 








INDEX 


~~ ~~~. ~~. _2 > o> 


5 2-14, 2-15 
: . « B-1 
a 2-4 

. oe ew S20 
ees et hg EO 
Sania) we eee 
2-17, 2-18 

eee en ee 

ssa ee a 

Es ig a: Sos 2S 

2. 10, 3-36 — 3-37 
ete a eS 

a eas ARTZ 

, F-5 — F-7 
-. . 29, 3-3 

~ - . 1-2 


. . 2-17, 2-18 
see See aS 


. .2-10 
: m 3-1 
. 33— a: 42 


insertion into transport 

peripherals . . ... 

Protecting .... - 

specifications 

storage . . -...- 

syntaxes . . . . ss 
chapters 

summary .. . 

tabbed index Pa 
checking a halted program 


cleaning 
calculator P 
cassette transport 
CLEAR key ... : 


COM (common) statement 
common logarithms (LGT) 
CONT (continue) key 
continuing a program 
with CONT ..... 
with STEP . 2... 


COS (cosine) function .. . 


DEF FN statement 


multiple-tine 


single-tine wy. Get tae et. 
DEG (degrees) 

command be pat ose 

statement 


DEL (delete) eeramend 
delete character space 

with SHIFT INSERT 
DELETE LINE key 
DIM {dimension} statement 
DISP (display) statement 

with TAB P 
display keys 

Pty ecw oe. Js 


“- -> 
e 





e (exponential function) 
editing 

in calculator mode 

in programming mode 
END ~ 

key ....- +s 

statement sie ie) a 


. . 5-4, 5-25 
es | 
Soe ie 


4-11 — 4-12 


- 2... AS 


. «. 41,44 


- .. .4-10 
. 2-17, 2-18 


3-33 — 3-35 
~ 2 « «dae 


2-17, 2-18 
- . «342 
- . - 48 


. 2-14, 2-15, 2-16 


sb ser Qe 
coer we ot AB 
3 ae eT 

ode, Fa 
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CARD NO. 


CALCULATOR PROGRAM CARG 


STEP| KEY CODEISKIP] 100; 40 20 


a eo (55 


o| 6 166) 
is} + | 


[a] 
B 
El 
0) 
| 


s 
co 
Ss 


oO 
ei 
ifo}o 


ee eA RUA REG ER LEN A LESS Key OL Rea KEP KES KD BBD UO 


C1) Strobe Marks. 
Q) SKIP is marked to cover an error. 


@ SKIP 177 turns the reader off. SKIP 177 ts not a key-code — it 
is an instruction to the Mode! 60 only. 


@) Insert card into the card reader, printed side up, in the direction 


= a! = 





=— _ 


| 
| 


Uj) OO; OO} 0} 0) 00 


SOOO; O; OO OOOO G0 
}O)0 U 
OO Ot ie 


OOOO O)OyU;OPU POO] HOT 


NOU; OPO OO O;OPO OG oe 


0}0 





0 


O/B /O;0)O) O)0;0,0) 0/0) to 





. USE SOFT PENCIL 


. ERASE COMPLETELY 
INSERT THIS SIDE UP 
MARKING SKIP COLUMN CAUSES 


THAT ROW TO BE SKIPPED. 
Part No. 9320-2085 


ZBazew WE 


NOTES 


indicated by the arrow. 


Figure D-2. The Program Card 
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APPENDIX E 
ERROR CODES 


The error codes and messages listed in Table E-2 are also located on a slide-out card 
underneath the Model 30. 


When an error occurs, the calculator makes a soft beeping sound and an error code 
appears on the display. The error message that corresponds to this code helps to pinpoint 
the cause of the error. Errors can be either recoverable or non-recoverable. The 
differences between the two are discussed next. 


~®> RECOVERABLE vs NON-RECOVERABLE ERRORS <> 


Most errors are non-recoverable. When a non-recoverable error occurs in the calculator 
mode, press the RECALL key to return your input to the display. Make suitable 
corrections as referenced by the error message and then re-execute the line. 


Recoverable errors (error 100 through 107) occur when you are working with very farge 
or very small numbers. When a recoverable error occurs, an approximation of your result 
appears on the display together with the appropriate error code. 


lf, say, you execute the following: 
A = 1.2E63*4E41 


The display is: 





The code, ERROR 100, indicates that the positive range of the calculator has been 
exceeded. In this example the variable, A, is set equal to 9.99999999999E+99. (All the 
9's are not displayed if you are in the standard mode.) The variable, A, can then be used 
in further calculations. 


lf either a recoverable or a non-recoverable error occurs during program execution, the 
program halts. If the error is recoverable, the program can be continued from that point 
if you press the keys — CONT EXECUTE. But if the error is non-recoverable, the 
program must be corrected and re-executed. 
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> >.<. ~~ ERROR MESSAGES <-<o ooo « 


Table E-2 is a duplicate of the slide-out, error-code card underneath the Model 30. Please 
keep in mind that the error messages only help to reference an error. In some cases, the 
particular error that is displayed may not pinpoint the specific error that occurred. 


Errors 4 through 8 are general errors; they are often displayed before the calculator can 
determine a more specific error. 


Table £-1, below, gives some additional explanations to particular error-code messages. 


particular ROM is run without having the ROM installed. 


FRREOR 1 ROM configuration error; occurs if a program that requires a 


] 
Table E-1. Additional Error-Message Explanation 
| 
| 


Memory overflow; occurs if the calculator needs more memory 

ERROR: than is available. (Remember that during program execution, 

men ari the calculator temporarily uses a small portion of user 
memory.) 


Missing line number or integer, or integer out of range; often 
occurs when END OF LINE is pressed instead of EXECUTE. € 


No statement or command recognized; often occurs if END OF 
LINE is pressed instead of EXECUTE, or vice versa. 


ERROR 46 Variable or function is undefined; most commonly occurs if the 
Epi es : simple variable specified does not have a value. 


Line not found; occurs if the line referenced in a statement is 
not in memory. 


Cassette status error; occurs a} if the cassette door is open or 
slightly ajar; b) if the end of tape is reached without finding the 
specified file; c) if the cassette is protected (see Chapter 5); d) if 
the specified peripheral cassette memory is turned off; e) if a 
STOP command is given while information is being recorded on 
tape. 

ERROR 54 Check sum error; often occurs if the tape head is dirty or if the 

STRATE ot portion of the tape accessed is damaged. 


Improper file size; also occurs if there is no COM statement in 
ERROR 6h memory and you attempt to STORE DATA without the array 
specification. 





A fold-out of both the error codes and the calculator keyboard is included here for 
your convenience. 


Le ARN a ee Ree 


Those error codes that are related to the ROM’s are given in the back of the ROM 4 
manuals. 
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an 


10 
"1 
12 
13 
14 
16 
16 
7 
18 
19 
20 
21 


23 


Memory configuration error 

Memory overflow 

Statement is not allowed in keyboard mode 
Missing line number or integer, or inveger 
out of range 

No statement or command recognized 
Improper arithmetic expression, 
number or expression 

Characters follow statement’s logical end 
Missing punctuation in program statement 
invalid command unless in KEY mode 

User KEY is undefined 

Exponent is out of range 

Two decimal! points in number 

Sign given without number 

Missing comma 

Missing left parenthesis 

Missing right parenthesis 

Missing subscript 

String not permitted 

No opening quote or missing string variable 
No closing quote 

Missing or improper function identifier 
Missing function parameter 

Missing or incorrect DATA item 


missing 


100 Numeric overflow (assumes + oF - 99} 
107 Numeric underflow (assumes Q) 
102 LOG or LGT of zero tassumes -oo) 


Note: 


9830 NON—RECOVERABLE ERRORS 


24 
25 
26 
2? 
28 
29 


30 
31 
32 
33 
34 
35 
36 
37 
338 
39 
40 
41 
42 
43 
44 
45 
46 


103 
104 
105 
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Table E-2. Error Codes 


Improper {F.... THEN statement 

Missing OF in conditional GO TO statement 
Missing variable 

Missing or improper FOR variable 

Missing TO in FOR statement 

Missing STEP or illegal characters following 
FOR statement 

Missing assignment operator 

Missing or improper assignment 

Improper FORMAT specification 

COM statement rules not followed 

Improper common declaration 

Array is doubly defined 

Precision of variable is doubly defined 
Inconsistent dimensions are given 

Array has unknown dimensions 

Dimensions are too large 

Variable or function is undefined 

Array or string has not been initialized 
Subscript exceeds bounds 

Select code exceeds bounds 

Line not found 

tmproper statement type referenced 
Improper statement nesting in multiline 
function 


9830 RECOVERABLE ERRORS 


Division by zero fassumes + or - oo} 


Zero to negative power (assumes + oF 
tnteger variable overflow (assumes + oF 
-32767)} 


47 


49 
51 
52 
53 
55 


57 
58 


Improper RETURN 

FOR statement has no matching NEXT or 
incorrect FOR nesting 

Out of DATA 

Last statemen: is not END 

LOG or LGT of negative number 

SOR of negative number 

Zero to zero power 

Non integer power of negative number 
Cassette operation statement syntax error 
Wrong file or file nat found 

Improper operation on SECURE program 
Cassette status error 

a. Door open 

b. Clear leader 

c. Write not permitted 

d. Cassette power off 

e. STOP given during a write operation 


59 Check sum error 
60 Improper file size 
61 improper precision or data type 
62 Improper file type 
2 Program overlay 
106 Split variable overflow {assumes + or 
-9.99999£+63) 


407 Split variable underfiow (assumes O} 


The calculator approximates + and - 0 by 9.99999999999E+99 and -9.99999999999E+99, respectively. 
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: APPENDIX D 
MODEL 60 CARD READER 


This appendix describes the use of the Model 9860A Card Reader with the Model 30 (see 
Figure D-1}. if you have purchased or if you are considering the purchase of this 
peripheral, you should read this appendix. 





Figure D-1. 9860A Marked Card Reader 


~~. ~~ GENERAL INFORMATION ~—<-—°—-o—o 


The Hewlett-Packard Model 9860A Marked Card Reader simulates a remote keyboard by 
allowing most operations that are available with the Model 30 Calculator. Key sequences 
are encoded on special cards. These cards are fed through the Model 60, which, by using 
an optical technique, senses the various combinations of marks on the card. There is a 
combination of marks to represent most keys on the Model 30 keyboard, and as a 
combination is detected, it is as if the associated calculator key has been pressed. A card 
is encoded to represent a series of keys by marking various combinations of boxes on the 
card with an ordinary black lead pencil. 


The Model 60 does not require any special ROM to operate with the Model 30, nor are 
there any syntaxes associated with !t. 





The Card Reader Operating Manual (see Table D-1) describes the use of the card reader 
with the 9810A Calculator. Refer to that manual! for general information about your card 


reader. 





APPENDIX DO 


The accessories and equipment suppiied with the Model 60 are tisted in Table D-1. 
(Continued) 
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>—e> <-> GENERAL INFORMATION ~~. 


(Continued) 


Table D-1. Card Reader Equipment 


2 









-hp- Part Number 











Operating Manual 09860-90001 
Interface Cable Assembly 1 09860-61605 
AC Power Cord 8120-1575 
Spare Lamp* 09160-67901 
Program and Data Card 9320-2085 


(The following iterns are not 
used in a 9830A Calculator 

























system.) 
Diagnostic Card . 09860-90002 
Data Card 9320-2088 
Supplement A 09820-90050 


Model 20 Program and Data Card 09320-2885 


T Located in the instrument — see ‘CHANGING THE LAMP’ in the operating manual. 


> o->—-*> CARD READER OPERATION <——o—-—o> 


[INSPECTION <e-—-__ _—— 


Refer to ‘Inspection Procedure’ in Appendix A of this manual. 


INSTALLATION <2 _-______________/_/_____ 


CAUTION 
DO NOT APPLY OPERATING POWER TO THE MODEL 9860A 


MARKED CARD READER UNLESS THE LINE VOLTAGE SWITCH ON 
THE REAR PANEL IS IN THE PROPER POSITION. OTHERWISE, 
DAMAGE TO THE POWER TRANSFORMER MAY RESULT. 





Refer to Chapter 1 in the Card Reader Operating Manual for information concerning 
power and grounding requirements and installation procedures. Refer to Chapter 6 of 
that manual for the procedure to replace the lamp. 


USING THE CARD READER ——#Y-—-—_______________- 


The Model 60 Card Reader acts somewhat like a remote keyboard to the calculator. A 
card is marked, in a simple code, with the desired key sequence and the card is passed 
through the reader. The calculator then behaves as if the calculator keys, corresponding 
to the encoded key sequence, have been pressed. 


Almost any key or key sequence can be input to the calculator from the card reader. 
Inputs can include data, expressions, program statements, and ‘immediate execute’ 
commands (such as CLEAR, PRINT ALL, EXECUTE, etc.). 
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The card reader starts automatically as soon as a card is fed in. The card passes through 
the reader at a constant speed so that the key codes are read and input to the calculator 
at regular intervals. There is no system of ‘interrupt’ between the calculator and the card 
reader so the calculator must be either idle or at an INPUT statement before the card 
reader can be used.* 


Because there is no interrupt possible, any instruction which causes immediate activity on 
the part of the calculator, such as END OF LINE or EXECUTE, should be the last 
keycode on the card. If other keycodes do follow, some of them may be missed by the 
calculator while it is carrying out the earlier instruction. It is possible to encode ‘skips’ 
on the card to give the calculator extra time to complete an operation before it receives 
the next keycode. However, this is not recommended because the number of skips 
required is difficult to predict (e.g., it obviously takes longer to enter an 80-character line 
into memory than it takes to enter a 10-character line). 


Table D-2. Key Codes 


KEY KEY KEY 
} cope (or symbol} ne (or symbol!) SEE (or symbol) “ee 


fy (note 1) Saal Bar 







KEY 
{or symbol) 













{not used} 
a {note 3) 
b 
















i 

CLEAR 

RESULT 
] 


a 





+ 


EXECUTE 













O2Z2rnrxAue—-zt AnNmMVAOeYr@ 


CONT 

STEP — m 
TRACE ; n 

RUN / ENTER EXP 


















































LOAD 


Kelis «) 







RECALL 0 P PRT ALL 
FETCH 1 Q q 
BACK 2 R END OF LINE 

FORWARD 3 $ DELETE LINE 
+ (display) 4 T FIXED N 
t (display) 5 U FLOAT N 
< (display) 6 V SCRATCH 
> (display) 7 W AUTO = 

Xx 

Y 

Z 

{ 


















STORE 
INIT 7, 

/ 4 {not used} 
END < B (note 2} (not used) 
STD = {not used) 

NORMAL > t (not used) 
INSERT ? + {note 2} STOP 





Notes: 1 — fy 9 through f;9 not available via the card reader. 
2 — Codes 134 and 137 display a symbol! but serve no other function. 
3 - Not all of the lower case alphabet is available via the card reader. 


+ TRACE and NORMAL are the only instructions which can be input via the card reader while the calculator is 
running a program. 
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>>> CARD READER OPERATION —-—e—2—> 


(Continued) 





ENCODING 


NOTE 


Please read Chapter 2, The Model 60 Card, in the Card Reader Operating 
Manual, before reading the following material. 





Figure D-2 shows a card marked with two data numbers (94.62 and —136.328E6) to be 
input during an INPUT statement. Notice that the sequence of keys marked is exactly 
the same as the sequence which would be pressed if the data numbers were to be input 
from the keyboard. 


The card is divided into columns and rows; each row corresponds to one key. The 
extreme feft of the card can be used to write a title and date. The next column, labeled 
‘STEP’, is for use with the 9810A calculator (where every keystroke in a program has to 
have a step number); so it can be ignored. The two columns marked ‘KEY’ and ’CODE’ 
are for you to write the keys to be encoded and the code number for each key. Table 
D-2 shows the key corresponding to each valid code number (using invalid code numbers 
will produce unpredictable results). The columns of rectangular boxes are used for the 
actual coding that is read by the card reader. The card reader scans the boxes a row at a 
time and inputs the corresponding key code from each row into the calculator. 


Ignoring the SKIP column for the moment, the columns marked 100, 40, 20, 10, 4, 2 
and 1 are for marking the key-codes. These boxes are marked with a pencil, so that the 
value of the boxes marked on a row, when totaled, equals the code for the desired key. 
For example, the first key in the card shown in Figure D-2 is the digit 9, which has code 
number 71. 71 is encoded by marking boxes 40, 20, 10 and 1 (40+20+10+1=71).+ 
Similarly, the ENTER EXP key, which has code 157, is encoded on the card by marking 
boxes 100, 40, 10, 4, 2, and 1. (The E key, code 105, could have been used instead of 


ENTER EXP.) 


The SKIP column, if marked, will cause the Model 60 to ignore any boxes that are 
marked on that row. Marking the SKIP column can be used as an alternative to erasing; 
should you make an error in marking a row, you may either erase the error and correct 
it, or mark the SKIP column. fn Figure D-2 the digit ‘7’ was included in error, so the 
SKIP column was marked to prevent the card reader from reading that digit. 


Near the bottom of the card, there is a preprinted mark that intersects all of the boxes. 
This mark, interpreted by the reader as ‘SKIP 177’, causes the card reader to stop reading 
the card. When a ‘SKIP 177’ is seen by the card reader, no additional information on 
that card is transferred to the calculator. If you do not use all of the rows on a card then 
you must mark a ‘SKIP 177° immediately after the last row used. Otherwise, all 
unmarked rows will be interpreted as code ‘@’, the code for the fy key (and if f, is 
undefined, ERROR 10 will result). 


If a key sequence is longer than can be encoded on a single card, simply encode the first 
part of the sequence on one card, and the second part on another. Neither card needs 
any special encoding. Just insert the cards, one after the other, in the obvious order. 


+ The computer-oriented operator will recognize the marked boxes as representing the binary equivalent of an octa! 
number, 
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) 3 APPENDIX B 
GENERAL OWNER’S INFORMATION 


The information in this appendix should be read soon after the arrival of your calculator. 


>>. oe > EQUIPMENT SUPPLIED ~?°-o-oo 


The following items are packaged with your calculator: 
@® The items listed in Table 8-1, which are included with every Model 9830A 
Calculator; 


@ Two copies of either a manual or an operating note for the options installed in 
your calculator (except for the memory options, see page B-2); 


@ Any additional items listed in any extra manuals or operating notes. 


Plug-in ROM’s and peripheral devices are packaged separately; each of these has its own 
manual or operating note and may also have extra items packaged with it. 


Table B-1. Standard Accessories Supplied 


tem ~*YC Quantity] rip: Part Number 























Simplified Operating Instructions 2 09830-90000 
Operating and Programming Manua! 2 09830-90001 
Quick Reference Card 1 09830-90012 
Simplified Training Cassette 1 09830-90014 
9830A Program Pad 1 09830-90016 
9830A Math Pac, Vol. 7 2 09830-70000 
Tape Cassette — Math Pac 1 1 09839-70000 
Sheet of Math Overlays {1—6) 1 7120-3511 
Sheet of Math Overlays {7—9) 1 7120-3514 










Key Overlays: 














































Special Functions 1 7120-3053 
Basic 1 7120-3054 
Math 1 7120-3055 
System Test Cassette 1 09830-90035 
System Test Instructions I 09830-90032 
Tape Cassette — Blank 2 9162-0050 
One of numbers 
Power Cord 1 shown in 
Figure 8-1 
ROM Door Key 5040-7437 
Dust Cover 4040-0978 
8500-1251 


Magnetic Head Cleaner 

Cotton Applicators 

Spare Fuses — 250V Norma!-blow 
% in. dia. X 1% in. tg. 


! 























1-amp 2110-0001 x 
2-amp 2110-0002 = 
2110-0056 . 


6-amp 
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{Continued} 


Power cords with different plugs are available for the calculator. Each plug, together with 
the part number of the power cord which has that plug, is shown in Figure B-1. Each 
plug has a ground connector. The cord packaged with each calculator depends upon 
where that calculator is to be delivered. If your calculator has the wrong power cord for 
your area, please contact your local -hp- Sales and Service Office. 


S S m2 NSS 


8120—1351 8120-1369 8120—1689 8120-1348 8120-06987 
TUL approved for use in the United States with calculators set for either 220V or 240V operation. 


Figure B-1. Power Cords 








>>. > SERVICE CONTRACTS 


Service contracts are available for all -hp- calculators and calculator-related equipment. 
For further information contact any -hp- Sales and Service Office. 


~~~ —@——@~—e PROGRAM PACS -—.ococo 7c es 


Program pacs containing programmed solutions to problems from many disciplines are 
available. A Math Pac is supplied with each calculator. For a complete list of pacs and for 
pricing information, please contact any -hp- Sales Office. 


~——>———»—e—e KEYBOARD MAGAZINE ~.o o.oo 


‘Keyboard’ is a periodical magazine containing general information about Hewlett-Packard 
calculators and related equipment. It includes articles and programs written by calculator 
users; descriptions of the latest equipment and program pacs; programming tips; and 
many other items of general interest to calculator users. 


To receive your free subscription to ‘Keyboard’, please complete the order form supplied 
with your calculator. This will ensure that your name is added to the mailing list for 
‘Keyboard’. (Don’t forget to tear off, and keep, the warranty statement at the bottom of 
the order form.) 


~>—~@—~@—~@e—oe MEMORY OPTIONS ~..o co. oe 


The size of the memory in the basic calculator is 1760 (16-bit, 2-byte) words. A cal- 
culator with Option 275 installed has a total memory of 3808 words, while a calculator with 
Option 276 installed has a total memory of 7904 words. If your calculator has the basic 
memory or the 3808-word memory and you wish to add 4096 words to it, please order 
the 11281A Additional Memory Field Kit; our service personnel will then install the 
additional memory. 
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~~~». OPTIONAL EQUIPMENT —>—o—e—o—-o 


Various optional devices are available to increase the computing power of your calculator 
and the versatility of your system. 


These options consist of the ROM’s (described in Appendix C), which are additions to 
the calculator, and the peripheral devices (listed in Table B-2), which are additions to the 
system. Interfacing equipment is available to enable you to connect your caiculator to 
non-calculator-dedicated devices, such as teleprinters and measuring instruments. 


Following is a list of peripheral equipment (dedicated to the 9800 Series Calculator 
System) available at the beginning of 1973. As new equipment becomes available after 
that date, it will be described in the ‘Keyboard’ magazine and in data sheets available 
from HP Sales and Service Offices. 


Table B-2. 9800 Series Calculator Peripherals 


9860A Marked Card Reader 9865A Cassette Memory 
9861A Output Typewriter Q866A Printer 

9862A Calculator Plotter 9868A I/O Expander 
9863A Paper-Tape Reader 9869A Hopper Card Reader 
9864A Digitizer (available in summer, 1973) 


























>> CONNECTING PERIPHERAL DEVICES ©? 


Except for the 9866A Printer, which is described in Appendix A, peripheral devices 
connect to the calculator by means of an I/O (Input/Output) card. An I/O card can be 
inserted into any of the four slots at the back of the calculator (or into the 9868A 1/0 
Expander if it is used), as shown in Figure B-2. The card is constructed so that it cannot 


be inserted upside-down. 


One of Four I/O Stots with Spring Loaded Door 







\ AC Power Cord 


To periphera!S HO Card 


Figure B-2. Connecting an I/O Card 


Before connecting an I/O card, make sure that the calculator and peripherals are switched 
off. Slide the card as far as it will go (about 3-3/4 inches) into any slot. Then press the 
card firmly into place, to ensure that it is properly connected to the calculator. 
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; APPENDIX C 
ROM OPTIONS 


This appendix describes general ROM information and specifically describes the ROM’‘s 
that are available with the Model 30. 


~~ —~@e—@e—e GENERAL DESCRIPTION <2... 


ROM (Read-Only-Memory) differs from user memory in that information stored in a 
ROM is fixed. You cannot ‘write’ into a ROM in the same way, for instance, that you 
can write program lines into user memory. 


Several optional ROM’s are available for use with the Model 30. Each ROM consists of a 
block of memory (additional to the memory already built into the calculator) dedicated 
to performing specific tasks — controlling the plotter, enabling matrix and string variable 
manipulation, and so on. A list of ROM’s is included in this appendix. 


A ROM can be purchased in either one of two forms: as an accessory plug-in ROM or as 
an internal modification to the calculator. The calculator is capable of holding up to 
eight ROM’s at one time; any combination of up to five plug-in ROM’s and up to three 
internal ROM’s can be installed. 


The plug-in version of a ROM is a small block, about the same size as a tape cassette, 
which plugs into any one of the five slots behind the ROM door (see Figure C-1). You 
can install or remove a plug-in ROM in seconds. 


The internal ROM requires a modification to the calculator, which must be made by 
qualified HP personnel. Whenever an internal ROM is added to a calculator, an 
identifying decal (showing the option number of the modification) is attached to the 
inside of the ROM door, so that you can readily determine which internal ROM’s are 
installed in your calculator. 


Operation of either the plug-in or the internal version of the ROM is identical once it has 
been installed. Which version of a ROM you choose to order is, therefore, entirely a 
matter of your convenience. However, please remember that no more than three internal 
ROM’s can be installed, while up to five plug-in ROM’s can be inserted at any one time. 


~~. INSTALLING A PLUG-IN ROM ~—<-..~> 


The plug-in ROM’s are installed in the slots behind the ROM door, as shown in Figure 
C-1. A ROM can be plugged into any slot. 


Switch the calculator off and open the door by pressing on the ribbed part of the door. 
If the door is locked, use the key (shown in the figure) to unlock it; the key turns about 
% of a turn. 


Slide the block, with the label ‘right-side-up’, into any slot. Press the block firmly into 
place, to ensure that it is properly connected to the calculator. Close the door. 
(Continued} 
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>> ~~ INSTALLING A PLUG-IN ROM —.—~.—~» > 


{Continued) 


The door is spring-loaded so it is not necessary to lock it, unless you prefer to do so for 
security, or other reasons. 


Turn on the calculator, and the ROM is operational, 





Figure C-1. Plug-In ROM’s 


>> -—~-——e HOW TO ORDER A ROM ~e-_._e > 


To ensure that you receive the version of the ROM that you want, please order using the 
appropriate number, as described below. The different numbers for each ROM are given 
in the following section. 


@ To order a plug-in version of a ROM: 
Quote the accessory number. This consists of five digits followed by the letter ‘B’. 


Example: 
11271B Plotter Control ROM 


@ To order an internal version of a ROM at the same time that you order your 
calculator: 
Quote the option number. This consists of the last three numerical digits of the 
accessory number given to the plug-in version of the ROM. 


Example: 
Option 271 Plotter Control! ROM 


@ To order an internal version of a ROM after you have received your calculator: 
Quote the field kit number. This is the same as the accessory number except that it 
uses the letter ‘F’ (for ‘field kit’). 


Example: 
11271F Plotter Control ROM Field Kit 


Once the field kit is installed in your calculator, it becomes an option; so the kit includes 
the appropriate option decal to be attached to the ROM door. In the above example the 
decal would be marked ‘Option 271’. 





JO 


~~ ——o_-~o—~o—e THE ROM’S -~.°o cco -—- 


The ROM’s listed below are available at the beginning of 1973; as other ROM’s become 
available, they will be described in data sheets and tn the ‘Keyboard’ magazine. 





MATRIX OPERATIONS 


11270B (plug-in) 


Option 270 (internal) 


11270F (field kit) 


This ROM extends the BASIC language to include the statements used to manipulate 
matrices and array data. It provides fast solutions to simultaneous equations and to 
business and statistical problems, as well as providing convenient ways to handle large 
blocks of data. The determinant. operation (not normally available in BASIC) ts 
particularly helpful to structural and electronic engineers in solving their design problems. 


———> PLOTTER CONTROL 





112718 (plug-in) 
Option 271 (interna!) 
11271F (field kit) 


This ROM enables the Model 30 to contro! the HP 9862A Calculator Plotter. Using your 
own ‘problem’ units (as opposed to some artificial ‘plotter’ units) you can very easily 
draw and mark axes on the plotter, and plot points or functions. You can label the axes 
and plotted points and you can use your plotter as a printer, formatting the printout as 
well as specifying character size and printing angle. In addition, you can establish a 
unique ‘typewriter’ mode which enables you to print, on the plotter, one character at a 
time from the calculator keyboard. 


> _ EXTENDED 1/0 


11272B (plug-in) 
Option 272 (internal) 
11272F (field kit) 


This ROM enables a wide variety of peripheral devices to be controlled by the calculator. 
It allows a two-way transfer of information between the calculator and the peripheral 
devices and between peripheral devices. Data is transferred by means of standard ASCII 
code: however, automatic code conversion capability enables the calculator to be very 
easily programmed to receive and send other codes. In addition, various logic functions 
enable you to manipulate binary bits, thus increasing the variety of 1/O operations 
available. 
{Continued} 
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(Continued) 





STRING VARIABLES 


11274B (plug-in) 
Option 274 (interna!) 
11274F (field kit) 


This ROM enables the calculator to recognize and operate on letters and words (‘strings’) 
in very much the same ways that it recognizes and operates on digits and numbers. The 
calculator can be programmed to understand everyday language, making your programs 
truly conversational in style, and, consequently more easily used by personnel with no 
special training. 


TERMINAL ——\—_-H 


11277B (plug-in) 
Option 277 (internal) 
11277F (field kit) 


This ROM enables the calculator to be used as the terminal in many time-share systems, 
and yet still retain its calculator capabilities. The calculator’s own memory and 
text-editing ability have considerable cost-reduction advantages over other terminals. First, 
you can store and edit a program in the calculator and then transmit the complete 
program to the time-share system, thus saving on connect time. Secondly, you can store 
your programs in tape cassette files, thus saving on overnight and long-term storage costs. 
You can also send and receive program lines in languages other than BASIC, because 
syntax checking in the calculator can be temporarily suspended. 
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> ~~ KEYS AS FUNCTIONS —> 2-2 


{continued) 


The function name is immediately displayed: 
(FHA \) 


Solving for FNA3 is then accomplished merely by keying in the 3 and pressing the 
EXECUTE key. 


In this example the result, 24, would then be displayed. 


After the function is evaluated, the KEY mode is immediately exited. 


In the previous example, the function could also be called by a program that is being 
run. {f the program is in mainline memory and the function, FNA, is called, the 
calculator first searches mainline memory to see if the function is defined there: if it is 
not, the calculator then searches the first line of each Special Function key {in the order 
in which they were defined) to see if the function is defined on a key. If the program 
that calls the function is on a key, the calculator first searches each line of that program 
to see if the function is defined there; if it is not, the calculator then searches the first 
line of each Special Function key (in the order in which they were defined); finally the 
calculator searches mainline memory. Hence, it is possible for a function to be defined in 
more than one place. Then if a program calls on the function, the particular function 
called depends on the order of the search. 


Multiple-line functions can be on a key, also. As in single-line functions, just be sure that 
the DEFFN statement is the lowest-numbered statement on the key. By doing so, when 
the key is pressed, the function name appears on the display; then the function can be 
immediately evaluated. 


~>—~.—~»—e—»— KEYS AS PROGRAMS ~...e. > 


A Special Function key can contain an entire program. The program can be keyed in just 
like any other program once the specified key is accessed. Automatic line numbering can 
be used, the editing keys can be used, etc. 


Only the COM statement is restricted. If COM is to be used, it must be previously specified 
in mainline memory; furthermore, the number of elements specified by COM in the KEY 
mode can be no greater than the number specified in mainline memory — for there is only 
one common area allocated in memory. 


After a program is entered into a particular key, the KEY mode can be immediately 
exited if the END key is pressed. 


A program on a specified key can be run if you press: 
Eon 


The KEY mode is exited if the program is terminated by an END statement. 


Often it is more convenient to perform a ‘continue’ operation on a program in the KEY 
mode. This is Gone simply by pressing the appropriate Cé£). 


so; 


nee 
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y? 
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In this Case, no additional array variable storage is allocated, no variable vaiues are erased, 
etc. So if just the key is pressed, the program executes as though a CONT command had 
been given. 


The following example shows a simple application for using Special Function keys in this 
way: 


Example 
If the following program is in mainline memory: 


’ Mainline Memory 


my ey er 
F Mad aul ‘nl Natl 


oar “" 
a EE 





et RS | ee 
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fg 


$ 
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ful pnd. 
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When the program in mainline memory is run and line 20 is accessed, the number of 
entries to be keyed in must be specified. Then each time the program loops, another 
input is accepted. After the program is completed, the user can press —£— to determine 
the total of the inputs and the user can press —& 7 to determine the average of the inputs. 


In this example, if either of the following were pressed instead: 


Elon « (on 


an error would occur since the RUN command erases variable values specified in a 
previous program, in this case, Z and N, whose values are needed for the Special 
Function programs. 


If the program in mainline memory is run and the following entries are executed each 
time a ? appears: 
indicating the number of entries 


93 82 88 75 68 94 97 77 
a nel 


the 8 entries 


8 


When the program halts: 


@ If you press 74, the printout is: 


su Mt, mee 
i 


@ Jf you press CZ—, the printout is: 


YELP. Pi fe RP 2 
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~>—~——e ADDITIONAL KEY OPERATIONS ~—o—o ( 





KEYBOARD COMMANDS 


If you are in KEY mode, located at a specified key that contains a program, in general, 
operations can be performed the same as in normal mode: 


Alco ae 


oi to run the program. 


to display line 25. 


Ancona m 


an (2)(6)| 


to list all program lines, beginning at line 15. 


A 
© 
~) 


Other commands, such as REN and DEL, can also be used in this manner. 


To erase all information on the keys, press: ( 


=() 


which only erases information on keys. 


AaAcOMmMaM 


(a) erases everything on the keys — of course, it also erases 
fecRarcen : - 
everything else in memory. 


Whether or not you are in KEY mode, the following command does not erase programs 
or text on keys. 


memory. Furthermore, it does erase all variables defined in 


Of course, this command does erase all programs in mainiine 
the calculator. 


Some commands, however, can be directed at a particular key, whether it is a program, a 
function, or a typing-aid key. 


gural ("&_} where only the specified key ts erased. 


(a) CHD where everything on the specified key is listed. C 








CASSETTE COMMANDS 





The tape cassette commands were discussed in Chapter 5. However, those commands that 
can be used with the Special Function keys are mentioned here, also. (In these examples, 
file 5 is arbitrarily selected.) 


| : Everything on all the Special Function keys is 
=Ooo0 stored in file 5. . 


The information in file 5 is loaded back into 
wm(«)(e}(y)(s) memory in the same order in which it was 
extracted; that ts, the information previously in 


each f, will be loaded back into each f,. 


To load information into memory with a LOAD KEY command, the information must 
have been previously stored with a STORE KEY command. 


A program on a particular key can be stored in a file, too. First, access the key with a 
FETCH command. Then use a STORE command to put it in a file. 


The program in the specified f, is stored into file 5. 


(rercu] (_f } (stone i : : ‘ ‘ 
: (s) 1 (Typing-aid keys cannot be stored in this manner.) 


To load this program back on a key at some tater time, press: 


Once a key is accessed, other tape commands, like LINK and MERGE, can be used in 
this manner. 


KEY OVERLAYS 


Three overlays are supplied for the Special Function keys. They are easily inserted over 
the Special Function keys if you lock the extended tab on the right into the appropriate 
keyboard slot. Then press the overlay down over the keys and secure it with the left tab 
lock. 


Two of these overlays, BASIC and MATH, have words pre-printed corresponding to 
specified keys. If desired, each pre-printed word can be keyed into the appropriate f, asa 
typing-aid key. Then the STORE KEY command can be used to retain all the 
information on tape for easy accessibility. The third overlay, SPECIAL FUNCTIONS, can 
be labeled any way you want. 
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° APPENDIX A 


CALCULATOR AND PRINTER 
INSTALLATION PROCEDURES 


This appendix contains inspection, installation, and maintenance procedures for your 
calculator and printer. 


~>—_<»—@o-—@—e THE CALCULATOR ~<«co 72. 





INSPECTION PROCEDURE 


The various parts of your calculator system were carefully inspected before they were 
shipped to you. All equipment should, therefore, be free of scratches and should operate 
properly. Carefully inspect the calculator, plug-in ROMs, peripheral equipment, cables, 
etc., for physical damage sustained in transit. Notify HP and file a claim with the carrier 
if there is any such damage. 


Please check to ensure that you have received all of the items which you ordered and 
that any options specified on your order have been installed in your calculator. Decals 
located inside the ROM door (see Figure C-1) show the option number of any interna! 
option installed in the calculator. Also check to ensure that all accessories are present 
(refer to ‘Equipment Supplied’ in Appendix B). 


If you wish to check the operation of your system, or any part of it, refer to the System 
Test Instructions book, which contains the information needed to run the System Test 
Cassette. Before running the test, however, be certain that your calculator is properly 
installed. 


If you have any difficulties with your system, if it is not operating properly, or if any 
items are missing, please contact your nearest HP Sales and Service Office; addresses are 
supplied at the back of this book. 


—$— o> POWER REQUIREMENTS 


The Model 9830A Calculator has the following power requirements: 


@ Line Voltage: The calculator operates from nominal powerline voltages of 100, 120, 
220, and 240 ac volts. The range of operation is from —10% to +5% of each nominal 
voltage. Two switches on the rear panel of the calculator enable any one of the four 
voltages to be selected (refer to page A-3, Initial Turn-on)}. 


e@ Line Frequency: The calculator can be operated with any line frequency from 48 Hz 
to 66 Hz (nominally 50 Hz and 60 Hz). 

@ Power Consumption: With no peripheral equipment connected, the calculator requires 
a maximum of 150 vo!ltamps. 
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(Continued) 





POWER OUTLETS 


There are two power outlets on the rear panel of the calculator (see Figure A-1). These 
are used to supply ac power to peripheral equipment. No more than a combined total of 
610 voltamps must be drawn from these two outlets. The outlets are ‘live’ whenever the 
calculator is plugged in; they are not switched on or off by the LINE ON/OFF switch on 
the front of the calculator. 


Power Outlets for Printer Signal 


Peripheral Devices 
















Tak CLEEEELITD \Weep 
| | CTT Pe 
pt CUERTTTE p* 3 





be 
Sect caaeunae i 
Power Input 


Figure A-1. The Rear Panel 
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Powerline Voltage 
Switches 


Main Fuse 





GROUNDING REQUIREMENTS 


To protect operating personnel, the National Electrical Manufacturers’ Association 
(NEMA) recommends that the calculator keyboard and cabinet be grounded. The 
calculator is equipped with a three-conductor power cable which, when connected to an 
appropriate power receptacle, grounds the keyboard and cabinet of the caiculator. To 
preserve this protection feature, do not operate the calculator from an ac power outlet 
with no ground connection. 


USES ap 
The calculator has two fuses, which are located on the rear panel (see Figure A-1). 


The main fuse is a 6-amp fuse. [t protects the calculator and any peripheral devices 
connected to the two power outlets on the rear of the calculator. 


The calculator fuse is either a 2-amp fuse for 100 or 120 ac volt operation, or a 1-amp 
fuse for 220 or 240 ac volt operation. This fuse protects the calculator only. 


WARNING 
TO AVOID THE POSSIBILITY OF SERIOUS INJURY, ALWAYS DIS- 


CONNECT THE CALCULATOR FROM ITS POWER SOURCE BEFORE 
CHANGING A FUSE. 





To change a fuse, first disconnect the power cable from the calculator. Next, press 
inward on the fuse-holder cap while twisting the cap in the direction indicated by the 
arrow on the cap. Withdraw the cap and fuse from the fuse-holder and remove the fuse 
from the cap. Insert the replacement fuse (either end) into the cap; then put the fuse and 
cap back into the fuse-holder. Press on the cap and twist it in the direction opposite to 
that indicated by the arrow until the cap is properly locked into place. 
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With the calculator disconnected from its ac power source, verify that the correct 
calculator fuse has been installed for the powerline voltage in your area (refer to the 
previous section, Fuses). 


Next, ensure that the two switches on the rear panel are set for the correct powerline 
voltage. Figure A-1 shows the location of the switches and Figure A-2 shows the correct 
settings for each nominal line voltage. If it is necessary to alter the setting of either 
switch, insert the tip of any small instrument into the white slot on the switch. Slide the 
switch so that the position of the white slot corresponds to the desired voltage, as shown 
in Figure A-2. 
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Figure A-2. Switch Settings for the Nominal Powerline Voltages 


Switch the OFF/ON switch, located on the right front of the calculator, to the OFF 
position. 


Connect the power cord to the power input connector (Figure A-1) at the rear of the 
calculator; plug the other end of the power cord into a suitable ac power outlet. 


Switch the OFF/ON switch to the ON position; the symbol */’ will appear in the display 
indicating that the calculator is ready to operate. 


aes, CLEANING THE CALCULATOR 


The calculator can be cleaned with a soft cloth dampened either in clean water or in 
water containing a mild detergent. Do not use an excessively wet cloth nor allow water 
to penetrate inside the calculator. Also, do not use any abrasive cleaners, especially on 
the display window. 


The fan filter (Figure A-1) should normally be cleaned about every three months. To 
clean the filter, first turn the calculator off. Then remove the filter by prying it out with 
an instrument, such as a screwdriver; this is done by inserting the instrument into one of 
the slots on either side of the filter, and by prying the filter out from the rear panel. 
Clean the filter either by holding it under running water, or by washing it in warm, soapy 
water, followed by rinsing it in clean water. Dry the filter thoroughly. Finally, install tt 
again by snapping one side back into place, and then the other. 


if you have the 9866A Printer, follow the same cleaning procedure. 
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>> —>-> PRIMARY PRINTERS <->. >.> 


The ‘primary printer’ with the Model 30 is the printer which is set to select code 15. The 
HP 9866A Printer (Option 30) was designed specifically to be the primary printer for the 
Model 30. So the procedure to connect this printer to the calculator is included in this 
appendix, and operating information is in Appendix F. 


However, there are other printers that can be used as the primary printer. Although each 
of these printers has some unique requirements and features, all of them are controlled 
by the same statements as is the 9866A Printer. Two of these printers will be referred to 
in this book since they are representative of the types of printers that are available. The 
two printers chosen are the HP 9861A Output Typewriter and the ELEY Model 38 
ASR Data Terminal {teleprinter). 


Any printer other than the 9866A Printer requires an interface to connect it to the 
calculator. The typewriter is supplied with its own special interface. The teleprinter must 
be interfaced by means of the HP 11205A Serial !/O Interface; this is a general purpose 
interface used to connect, to the calculator, devices that meet Ef{A Standard RS-232-C. 


Installation procedures for the typewriter and teleprinter can be found in the manuals 
supplied with chem and in the manuals for the interfacing equipment. Operating 
information is included in Appendix F of this book. 


NOTE 
The 9861A Output Typewriter manual states that a calculator requires a 


ROM to control the typewriter. Despite that statement, no ROM is 
required to operate the typewriter as either the primary or as the 
secondary printer with the Model 30. 





> oo o> © THE 9866A PRINTER <-<o o> 





DESCRIPTION 


The -hp- 9866A Printer is a high speed, thermal line-printer capable of printing up to 240 
lines per minute with up to 80 characters per line. The Option 30 version of the printer 
connects directly to the 9830A Calculator and requires no special equipment to operate. 
The casing of the printer is designed to be placed either on any flat surface or on top of 
the calculator, as shown in the photograph on the title page of this book. 


General information about the printer — accessories, power requirements, turn-on 
procedure, ordering printer paper, etc. — is included in the Peripheral Manual {-hp- Part 
No. 09866-90000) supplied with the printer. Some of the information is also included 
here for your convenience. However, for complete information about your printer, please 
refer to the Peripheral Manual. 
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INSTALLATION AND TURN-ON —__——-__———— 


@ Power Requirements: The 9866A Printer has the same power requirements as the 
calculator, except that the printer has a maximum power consumption of 250 
voitamps (refer to page A-1, Power Requirements). 


® Grounding Requirements: Grounding for the printer is similar to grounding for the 
calculator, If the calculator is properly grounded, as described earlier in this appendix, 
use the inter-instrument power cord {-hp- Part No. 8120-1575} supplied with Option 
30 printers to ensure that the printer is also properly grounded. 


@ Fuses: The printer uses a 3-amp fuse for 100 or 120V operation or a 1.5-amp fuse 
for the 220 or 240V operation. If your printer is being turned on for the first time, 
ensure that the correct fuse is installed (refer to page A-2, Fuses). 


Before connecting the printer to the calculator, ensure that the correct fuse is installed 
and that the slide switches on the rear of the printer are properly set for the voltage in 
your area. Once the calculator switches have been properly set, the printer switches 
should be set to the same positions (see Figure A-2). 


Set the printer LINE switch to the OFF position. Then place the printer on top of the 
calculator and make the power and signal connections as shown in Figure A-3. The 
connectors on both ends of the interface cable are keyed for proper insertion into the 
sockets on the printer and calculator; both connectors are identical. To connect the 
cable, press the connector against the socket and slowly rotate the connector until you 
feel it align with the socket. Then twist the knurled sleeve on the connector clockwise to 
lock the connector and socket together. (Twisting the knurled sleeve counter-clockwise 
unlocks the connector.) The calcitlator and printer are now ready to operate. Set the 
LINE switches on the calculator and printer to the ON position. 


Interface Cable 

















Inter-instrument Power Cord 


Figure A-3. Connecting the 9866A Printer 


LOADING PRINTER PAPER —<-————----____-l__""_ 


The LOAD light, below the PAPER key, lights any time the printer is out of paper. To 
load paper, lift the lid and refer to the diagram underneath it to see how paper is loaded. 
Place the roli, with the free end as shown, into the printer. Then press the PAPER key 
unti! the paper emerges from the front of the printer. 
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; Chapter 6 
SPECIAL FUNCTION KEYS 


The Specia! Function keys, located in the upper left-hand portion of the keyboard, add 
considerable flexibility to the Model 30. 


There are 10 keys, labeled fy through f,, in this region. There are, however, effectively 
20 accessible Special Function keys since each key can be accessed normally or with the 
SHIFT key held down.+ 
The Special Function keys can be used effectively in three ways: 

@ To represent text (where text can be used as a typing aid). 

@ To represent either single-line or multiple-line functions. 

© To represent programs. 


These three uses will be discussed individually after a brief introduction to entering and 
exiting the Special Function mode (referred to heresfter as the ‘KEY mode’). 


~-—>—*> ENTERING AND EXITING KEY MODE <—~-—- 


To put information on a Special Function key, it is necessary first to enter the KEY 
mode by pressing: 


If there is no information on the key, the display will now be: 
Whenever you are in the KEY mode and you press the CLEAR key, this same display 
will appear. 





While in the KEY mode, you Can input as discussed in the following sections. 


To exit the KEY mode, merely press the END key. Often, the KEY mode is 
automatically exited when certain operations are performed. These Operations are also 
discussed in the following sections. 


ENTERING AND 


wu 
a 
° 
= 
> 
cs 
x 
CG 
2 
c 
x 
w &§ 





+ We will refer to all 20 keys as fy through f, 4: fy through f, in the normal mode, and f,9 through fg in the shifted 
mode. 


£ The particular key specified {f, through f,,) is the one accessed by the command. Any time f, is referred to in this 
text, any of the twenty keys can be specified. 
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~~~.» 2 KEYS AS TEXT ~<ooco.. > " 


A Special Function key can be used as a typing aid, as illustrated in the following 
example: 


Example 


First a key, say —&—, is accessed by the method previously shown: 
(reren} (“4 


If no information is on the key, — KEY }- — appears on the display. Then text can be 
entered if an asterisk (*) is keyed in first. If you plan to write a program with several! 
PRINT statements, you can key in: 


CG OlOCalces 


The END OF LINE key is necessary to complete the entry. After it is pressed, the KEY 
mode is automatically exited. 


Even if information is already on the key, the method just discussed can be used. But, 
when the END OF LINE key is pressed, everything previously on the key is erased. 


Once the key is defined as text, the text is immediately accessible. If you are writing a 
program and you want fine 55 to be a PRINT statement, press: ( 


and the display is: 


\) 





Then the rest of line 55 can be keyed in normally. 


Notice, anything already on the display is retained when the typing-aid key is pressed. 


Any Special Function key can be used in the manner just described. 


The text that is on a Special Function key can be a command; e.g., 
ax OQOOOOOOOC=) 


Then whenever you want to execute this. command, you can press: 


Ch 


R3=CORM A 


However, it would be more convenient if this were an ‘immediate execute’ command. If 
an asterisk both precedes and follows the command, it is immediately executable. For 
example, press: 


{reren]] (_& 
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and the*display is: 





This text can be edited to include the asterisk immediately after the text. Just press: 


and the line now in memory is: *LIST1,30* 


Then whenever you want to execute this command, just press: 
Ce) 


><. o <--> KEYS AS FUNCTIONS —~ oo oo 


A Special Function key can be used to store either single-line or multiple-line functions. 
(Single-line and multiple-line functions are discussed beginning on page 3-32.) 


To put a single-line function on a key, the function must be entered as a program line, as 
shown in the following example: 


Example 


First a key, say “49, is accessed normally: 
(reren} (fA) 


If there are program lines already on this key, they can be easily deleted if you press: 


Vee) 


(If there is text on the key, it is automatically deleted when the first program line is 
entered.) 


Asaf Ohm 


A DEFFN statement can then be input. It must be the lowest-numbered program line on 
that key. For example, key in: ; 


OUP VIOMONOWOOOWE=) 


Then to evaluate this function for a particular value of X, say 3, first press the 
appropriate key:* 
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{continued) 


¥ 1t doesn’t matter whether or not you are in KEY mode when you perform this operation, You could have previously 
exited from KEY mode if you had pressed the END key. 
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(Continued) 
#2 storing data (then after memory is erased) 
if TIM ASS] 
fi FOR [=f Tu ae 
2H ALT J=8e5GF1 
48 HET I 
2H STORE DATA 33 
BH ERT 





Line 50 in the original program stored the elements of array A into file 5. Since an array 
was specified in this STORE DATA command, the subsequent LOAD DATA command 
must also specify an array. The array name specified by LOAD DATA need not be the 
same as the array name specified by STORE DATA; however, it must be dimensioned at 
least as large as the stored array. 


NOTE 


If you have recorded data on a cassette using either an HP Model 10 or an 
HP Model 20 Calculator, you can load the data back into the Model 30 
Calculator. Use the LOAD DATA command witl. the ‘array’ specification 


— and be sure that a COM or DIM statement in memory is large enough 
to assign variable names to all the data being entered. If the data was 
recorded using the Model 20, however, it will be loaded into the Model 30 
in the reverse order. 
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~~ ~>———_——@——@e STORE KEY ~3° «oc «co 7c 2. 


The STORE KEY command takes the information that is defined on all the Special 
Function keys (see Chapter 6), and reproduces this information onto tape. 


Syntax: 
STORE KEY file 


Sometime later, after the information on the Special Function keys has been erased, the 
corresponding LOAD KEY command can be executed to put the information back on 
the Special Function keys. 


~~ —_>———_>—o—e |OAD KEY —<-co ec 7c 7c «co oo 


The LOAD KEY command takes the information that was previously recorded in a file 
(with the STORE KEY command) and reproduces it onto the Special Function keys. 


Each Special Function key can then perform the same operations that it previously did 
before being stored on tape; that is, a program, a function, or text previously defined on, 
say, fy, is once again defined on f,. 


Syntax: 
LOAD KEY file 


If, say, the information on the ‘BASIC’ key overlay (supplied with the Model 30) is 
entered onto the Special Function keys as text, it can be reproduced onto tape with a 
STORE KEY command. Then anytime this information is needed, the corresponding 
LOAD KEY command can be executed. 


Executing a LOAD KEY command is similar to executing a LOAD command in some 
respects. All variables not defined in a previous COM statement (see pages 3-39 to 3-41) 
are initialized. Similarly, operating modes like STANDARD and RAD are reset, and state- 
ment references for GOSUB/RETURN and FOR. . .NEXT are lost. 
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The LOAD BIN (Load Binary) command reproduces into the calculator memory, from 
tape, binary information {assembly language programs). The assembly language program 
may be, for instance, a system diagnostic or an 1/O subroutine. 


The assembly language program cannot be listed or displayed, nor can it be stored onto 
tape by the user. 


Syntax: 
LOAD BIN file 


NOTE 


Files on cassettes are tagged as unused files, binary files, data files, 
program files, or key files. If an attempt is made to load from a particular 


file and the specified command incorrectly identifies the file tag, ar error 
occurs. For example, executing the command, LOAD BIN 2, when file 2 
is a data file, causes an error to occur. 
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Beginning at the tape’s current location, the TLIST command prints the information that is 
contained in subsequent file [D’s (see Tape Structure, Figure 5-3). 


Syntax: 
TLIST 


The information for each file is printed on one line. There are no column headers 
identifying the information in each fine; the assumed headers and their explanations are as 
follows: 





FE File No. File Type Absolute Current Program Line Nos. Common 
x (Code No.) File Size File Size (First) (Last) Area: 
ES ee ee fin words) == finwords) | (in words) | 
1. File No. The first column always specifies the file number. 
2. File Type: The five file types are coded as follows: 
® for an unused file 
1 fora binary file 
2 for a data file 
3 for a program file 
4 fora key file. 
Furthermore, if the file is secured, (see page 4-15) a ‘2’ 
appears in front of the code number. For instance, the code 
for a secured program file is ‘23’. (Data files cannot be 
secured, however.) 
Absolute File Size: The length {in words) that the file was marked. 
4. Current File Size: The number of words currently being used. 


5. First Program Line No: For program files, this column displays the lowest line 
number on the file. Sut for data files, this column has 
another meaning. It is coded as follows: 


@ fora full-precision array 

1 for a split-precision array 

2 for an integer-precision array 

3 for variables stored via the COM statement. 


6. Last Program Line No: For program files, this colurnn displays the highest line 
number on the file. For any other file type, this column has 
no meaning. 

7. Common Area: For program files, this column displays the number of words 


of memory needed for the COM specifications. For any other 
file type, this column has no meaning. 
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CASSETTES 








> ——e > PERIPHERAL CASSETTES ©——?oo om 


Besides the tape transport built into the Model 30, up to nine peripheral cassette memories 
can be added to the Model 30. 


The peripheral is referred to as the 9865A Cassette Memory. Four cassette memories can be 
connected directly to the calculator through the four I/O slots in the rear panel. If you have 
a 9868A I/O Expander, however, up to nine cassette memories can be added (this would 
still leave four I/O slots available for other peripherals). 


If any of the peripheral cassette memories are used, all the commands previously discussed 
can still be used. But in order to specify which cassette is being accessed, the select code of 
the peripheral cassette must appear in the command immediately after the command name. 
For example, the following sample syntaxes can be used to specify a peripheral cassette: 


STORE = select code [,file] 

LOAD = select code , file {,1st line number[,2nd line number} ] 
FIND = select code, file 

REWIND = select code 

STORE DATA # select code, file [,array] 


All cassette command syntaxes can be updated in this manner to specify a peripheral 
cassette. The number sign ‘=’ is always required. 


Peripheral cassette select codes are identified as #1 through =9. The internal tape transport 
has select code +10: if no select code is specified in a tape command, select code +10 is 


assumed. 
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>>> ee CASSETTE SYNTAXES @——oo oom 


Legend 
brackets [ } — items enclosed within brackets are optional. 
coloring — colored items must appear as shown. 
array name — the letter used to define the array (A through Z). 
file — the file number: can be a constant, a variable, or an expression. 
1st line number — the first line number designated. 
2nd line number — the second line number designated; it can appear only if the first 
line number is designated. 
length — the files’ lengths; can be a constant, a variable, or an expression. 
no. of files — the number of files; can be a constant, a variable, or an expression. 


TT a 


FIND file 
Locates a specific tape file. 


LINK [file] or LINK file {, 1st line number {, 2nd line number} ] 
Works like LOAD but, in addition, it retains variables currently in memory. 


LOAD [file] or LOAD file [, 1st line number [, 2nd line number] ! 
Reproduces, into memory, programs that are on tape via STORE. 


LOAD BIN file 
Reproduces, into memory, assembly language programs that are on tape. 


LOAD DATA file [, array] 
Reproduces, into memory, data that is on tape via STORE DATA. 


LOAD KEY file 
Reproduces, into the Special! Function keys, information that is on tape via STORE 
KEY. 


MARK no. of files, length 
Establishes files with specified lengths. 


MERGE [file] or MERGE file [, 1st line number [, 2nd line number] } 

Inserts, between program lines in memory, program lines that are on tape via STORE. 
REWIND 

Rewinds the tape to clear-leader. 
STORE [file] or STORE file [, ist line number {, 2nd line number] } 

Reproduces, onto tape, programs that are in memory. 


STORE DATA file [, array] 
Reproduces, onto tape, data that is in memory. 


STORE KEY file 
Reproduces, onto tape, information that is on the Special Function keys. 


TLIST 
Prints information about each file. 
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£ the first line of the loaded program; that is, if there were no lines after the 
LOAD command in the original program, or if the lines were destroyed by the 
LOAD command. 


® If the 2nd line number is specified, program execution is ‘restarted’t with this 
line number. 


Examples 


For the following examples, assume that lines 5, 15, 25, .. . 95 are originally in memory 
and that lines 10, 20, 30, ... 100 are in file 4. 


LOAD 4: The program lines from file 4 replace all the program lines previously in 
memory. 


LOAD 4, 10: All program lines from file 4 are loaded into memory. The first line 
loaded into memory is assigned line number 10 and the other lines are appropriately 
renumbered (however, in this example, the first line loaded into memory was already 
line number 10 — so no renumbering is necessary). Only the program lines previously 
in memory, with line numbers lower than 10, are retained; so in this example, line 5 
is retained. Therefore, the lines in memory would be: 5, 10, 20, 30, ... 100. 


LOAD 4, 30: This is like the previous example except that, in this case, the 
renumbering is necessary since ‘30° does not corres,ond to the first line loaded into 
memory. After this command is executed, the lines in memory are: 5, 15, 25, 30, 40, 
50, ... 120. Notice that lines 5, 15, and 25 are retained. 


LOAD 4, 30, 5: This is like the previous example except that, in this case, after the 
command is executed, program execution begins at line 5. 


The following examples use LOAD in the programming mode: 


#1 in memory in file 7 
SEIS 18 ABS 
im Y=4 2B B= 
aS LOA lee ENT 


When line 95 is executed, the program in file 7 replaces all program lines previously in 
memory. The new program then begins execution at line 10. 


#2 in memory 


med rd 

| ie a ie moe OT 

me oe TL re 1 
no 





Trlt bet Tt 


al a 
fs. fact 


Pode ti -' 


ce a Fay pale 


cry * 


This is like the previous example, except that both programs have a COM statement. So, 
even though the original program is replaced by the program in file 2, variables that are 
‘common’ to both programs (via the COM statement) retain their current values. 


+ The term, ‘restarted’, is used here because, during program execution, the LOAD command functions as though — 
RUN EXECUTE — had been pressed: variables (except for those defined by COM) become undefined, operating modes 
like STANDARD and RAD (radians) are reset, etc. 
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(Continued) 


#3 in memory in file 8 after 
LOAD command 
2 COM fe4 18 SSRt+y — GUM fay 
is A= 2 DISP ¢ te Z=A+4 
25 Yad - fu DISF = 
: 196 EXT ; 
35 LOAD 2.18 188 EMD 


When line 95 is executed, the program from file 8 is loaded into memory beginning at 
line 10. The COM statement, line 5 in the original program, is retained since this line is 
numbered lower than line 10. Since the COM statement is retained, the values of the 
variables, X and Y, are also retained. 


#4 in memory in file 4 after 
LOAD command 
= Tse 16 M=5 5 ps6 
is E=F 2 W=6 im E=-f 
2a LOAD [-2s 38 5 : 
. aa [Ss oe pas : = 

45 Farsi 14a END 40 E=E+1 
So poi aa hat Mt oe 
. BA Mae 
30 EME 
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is 


When line 25 is executed, the entire program in file 4 is loaded into memory and 
renumbered beginning at line 50. All lines previously in memory that are numbered lower 
than fine 50 are retained. Program execution is then restarted at line 35 since this line 
immediately follows the LOAD command. [In this example, however, error 40 (unde- 
fined variable) would occur in line 45 since the variable {E) no longer has the value 
assigned to it in line 15; the LINK command, described in the following section, could 
have been used here instead of LOAD.] 


#5 in memory in file 6 after 
LOAD command 
a Ls? 18 SSHTS+E a fis? 
{a RSs : it E=s 
at ao aia ce . 9% Gotan 
ce et fa eet ae erat m, Pe eau ake a Su oe a! bare Oe, 
* SA GOTO if : 
; LAA ERR : 


When line 95 is executed, the entire program in file 6 is loaded into memory and 
renumbered beginning at line 20. (Notice that the number referenced in the GOTO 
statement (line 90, file 6) is also appropriately renumbered.] Since lines 5 and 15 from 
the previous program are lower than line 20, they are retained. Program execution is then 
restarted at line 5. 


lf a COM statement is in the original program and if a LOAD command erases COM, the 
variables specified in COM can no longer be accessed; but a portion of memory is still 





mee 


allocated to the *’common’ variables. Then if another program, having COM, is !oaded into 
memory, the ‘common’ variables are once again accessible. 








Increasing Effective Calculator Memory 


As shown in the previous examples, LOAD can be used to chain programs together, piece 
by piece. With a COM statement in each program segment, only the variable values 
needed in each program segment are retained, and the program lines in the previous 
segment can be erased. So a maximum of memory is always available. Therefore, it is 
possible to execute, a portion at a time, programs that would otherwise be too large to 
execute on the Model 30. 


Like the LOAD command (see previous section), the LINK command takes programs that 
are stored on tape and reproduces them into the calculator memory. 


LINK and LOAD have the following differences when executed: 


@ With LOAD, the vafues of variables not referenced in COM statements become 
undefined; whereas with LINK, all variable values are retained. 


With LOAD, the calculator reverts to normal operating modes, like RAD and 
STANDARD: whereas with LINK, the current operating modes, say, DEG and 
FIXED 2, are retained. (But the data pointer is reset with either LOAD or LINK 
— see DATA statement, page 3-18.) 


The LINK syntaxes parallel the LOAD syntaxes: 


LINK [file] 
or 
LINK file [, 1st line number [, 2nd line number] ] 


The specifications in the LINK syntax follow the identical rules as the specifications in 
the LOAD syntax. 


There is no key for the LINK command, so the word, LINK, must always be typed in. 
Since LINK is most useful in the programming mode, the following examples show its 
practical uses. 

Examples 


in file 2 


5" 


#1 memory 
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When line 95 is executed, the program on file 2 replaces all program lines previously in 
memory. This program then continues execution with line 10. The variables, X and Y, 
defined in the original program, retain their values. Also, operating modes that were 
defined in the original program (like FIXED 3) are retained. Had LOAD been used 
instead of LINK, the variables, X and Y, would have been undefined; and the operating 
mode, FIXED 3, would have reverted to STANDARD. 

(Continued) 
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#2 in memory in file @ after 
LINK command 
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When line 25 is executed, the program in file @ (since the variable, Y, equals @) is linked 
to the existing program beginning at line 30. Program execution then continues at line 
30. The last statement in this program, 100 GOTO 15, returns the program to line 15 
where the variable (Y) is incremented by 1. When line 25 is again accessed, the program 
in file 1 will then be linked to the current program in memory. 





+ This statement is acceptable since renumbering does not occur in this example. 


| ~~~. 2.» MERGE 2.2. <. <<. 7° > ( 


The MERGE command takes program ‘ines from a tape file and positions them in 
memory in front of the program currently there, between consecutive lines in the 
program currently there, or behind the program currently there. 

The MERGE command always retains the program lines previously in memory. 


The following simplified syntax can be used: 
MERGE [file] 


The file specification is optional; if no file is specified, file @ is assumed. 


Examples 





In these examples assume that the following six program lines are in memory: 
10, 20, 80, 90, 100, 110 


e If the program lines in file 7 are 30, 40, 50, 60, and 70, then the following 
command could be executed: 


‘MERGE 7: This inserts program lines between lines 20 and 80 of the program 
currently in memory. Then the program lines in memory would be 10, 20, 30, 
.-- 110. 
e If the program lines in file 8 are 1, 2, 3, ... 9, then the following command ( 
could be executed: 
MERGE 8: This inserts program fines in front of the program currently tn 


memory. Then the program fines in memory would be 1, 2, 3,...9, 10, 20, 80, 
90, 100, 7110. 
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e If the program lines in file 9 are 115, 125, ... 205, then the following command 
could be executed: 

MERGE 9: This inserts program tines behind the program currently in memory. 
Then the program lines in memory would be 10, 20, 80, 90, 100, 110, 115, 125, 
... 205, 

e lf the program lines in file 10 are 85, 95, 105, 115, the command — MERGE 10 
— could not be executed since the line numbers in the two programs cannot be 
interwoven; any attempt to do so results in an error. 

e {f the program lines in file 11 are 20, 30, ... 70, the command — MERGE 11 — 


could not be executed: for if any line number on the file matches a fine number 
currently in the program (in this case, line number 20), an error occurs. 


For more sophisticated applications, the syntax is: 
MERGE file [, 1st line number [, 2nd line number] | 


The syntax specifications are much ftike those for LOAD and LINK. If the 1st fine 
number is specified, the program ijiines on the specified file are renumbered beginning 
with the Ist line number. The spacing between renumbered lines remains the same. 


tn the calculator mode: 


@ If the 2nd line number is not specified, the calculator halts after the program 
lines are merged. 

@® If the 2nd fine number is specified, program execution begins at that line after 
the program fines are merged. 


tn the programming mode {that is, after the program lines are merged): 


@ If the 2nd line number is not specified, program execution is restarted* with the 
line immediately following the MERGE command. 


@e if the 2nd sine number is specified, program execution is restarted? at that line. 
Examples 


For the following examples, assume that the program lines currently in memory are 70, 
80, 90, 100. 


@ lf file 4 has lines 20, 30, ... 70, the following command can be executed. 


MERGE 4, 10, 10: By specifying the 1st line number as 10, the program Sines 
from file 4 are renumbered so that they will fit in front of the program lines 
currently in memory. Then the lines in memory are 10, 20, ... 100. Since the 
2nd line number is specified as 10, program execution begins at that line. 


@ If file 5 has lines 1, 2, ... 100 and you want to insert these lines between lines 
70 and 80 currently in memory, it would be necessary first to renumber the lines 
currently in memory to allow for a 100 line insertion. The command — REN 
700,200 — achieves this and renumbers the lines in memory to 700, 900, 1100, 
1300. So the MERGE command could then be — MERGE 5,750. The fines in 
memory would then be 700, 750, 751, 752, ... 849, 900, 1100, 1300. 


¥ Restarting program execution means that although the program does not halt, the values of variables are erased and 
Operating modes are reset. 
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The FIND command is used to locate a specified tape file. It has two primary functions: 


@ It is used with the MARK command to locate the tape file at which marking is to 
begin. 


@ It is used to locate the next tape file that is to be accessed. This can have 
considerable time savings in either the calculator or programming mode since 
other operations can stili be performed while the FIND command is being 
executed. 


The syntax is as follows: 
FIND file 


As soon as the FIND command begins execution, the tape searches forward until the first 
file 1D is encountered. When it is encountered, both the direction and the number of files 
that the tape must travel are known. At this point, control of the calculator is regained by 
the user while the tape continues to search for the desired file. In the caiculator mode, 
control is regained when the symbol! ‘+’ appears on the display; whereas in the 
programming mode, control is regained when the program continues executing. (Inciden- 
tally, in the programming mode, if any other cassette command is encountered while the 
FIND command is still executing, the FIND command is immediately overridden by the 
new cassette command.) 


Example 
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When line 100, FIND 8, is executed, the tape cassette searches forward to determine its 
correct location. When the first file ID is found, the tape continues the search in high 
speed and the program continues execution at line 110. When line 200 is finally accessed, 
the tape is already positioned at file 8, so the LINK command can be immediately 
executed. (However, if file 8 had not already been located, the LINK command would 
have overridden the FIND command, continued the search, and performed the linking 
operation.) 
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The REWIND command causes the cassette to rewind to clear-leader. However, any other 
cassette command immediately overrides the REWIND command. 


All other cassette commands have their execution terminated if the STOP key is pressed. 
But the quickest way to terminate the REWIND command is to open the transport door. 


The syntax is simply: 
REWIND 


In the calculator mode, the internal tape cassette is most easily rewound if you press the 
REWIND key. But in the programming mode, REWIND must be keyed in, fetter by 
letter. 


In the programming mode, the REWIND command can be specified after all other 
cassette commands to ensure that the tape is on clear-leader when the program is finished 
and the cassette is removed from the transport. 
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The STORE DATA command takes data from memory and reproduces it onto tape. Data 
can be specified in either of two ways: 


@ If an array name (A through Z) is specified in the command, the value of each 
variable in the array is stored in a tape file. 


@ {f no array name is specified in the command, the values of all variables defined 
in a COM statement are stored.+ (From a COM statement, both simple and array 
variables can be stored.) 


The syntax is: 
STORE DATA file [, array] 


As mentioned, if the array is not specified, the variables referenced in the COM statement 
are stored. 


All variables stored need not have assigned values. For instance, a 20 element array _ 
A(20) — could be stored on tape, while an element within the array, say, A(6), has no 
defined vatue. 


The STORE DATA command can be executed in the calculator mode. But to do so 
generally requires either a COM or a DIM statement in memory and always requires that 
the calculator must have been previously initialized by either a RUN or an INITIALIZE 
command. 


Here are two examples of using STORE DATA in the programming mode. 








Examples 
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Example No. 1: In this example the STORE DATA command, line 70, references a 
variable file (Z), which is assigned a value in line 60. Since no array is specified by 
STORE DATA, all variables referenced in the COM statement are stored on the specified 
file. 


Example No. 2: In this example the STORE DATA command, line 50, references file 3 
and array B. So all the variables in the 8 array are stored in file 3. Notice that although 
B(1) through B(30) are all stored, B(26) through B(30) remain undefined. 


* For those who have the ‘String Variables ROM’ — string variables can be stored only in this manner; that is, by being 
referenced in a COM statement. 


The filé specified by STORE DATA must be large enough to include the entire array 
even if many of the array variables do not have assigned values. 










NOTE 


In general, it is a good idea to mark file sizes larger than the information 
that is going into the files. This is especially true when storing data. 


~@—-@ —~@—o—~e—~@e LOAD DATA «oc 72. oc oc oo 


The LOAD DATA command takes the data that was previously recorded in a file (with 
the STORE DATA command) and reproduces it into memory. 


The syntax parallels the STORE DATA syntax: 
LOAD DATA file [, array] 


If an array is specified in the STORE DATA command, then the LOAD DATA command 
that subsequently accesses the same file must also specify an array {although the array 
name specified need not be the same as the one used in the STORE DATA command). 


If no array is specified in the STORE DATA command, then the corresponding LOAD 
DATA command cannot specify an array. If STORE DATA did not specify an array, the 
variables from the COM statement were stored; so when the corresponding LOAD DATA 
statement is executed, a COM statement that parallels the previous COM statement 
should be in memory. 





Examples 
#1 storing data (then after memory is erased) 
loading data 
i COM Aeesalle 3 : 
2 AS oS 
3 Bib. & 
4 CLiis2 : 
a ies 0 ea ree . 
6 STORE DATA GG END 
F EHD 


Line 6, STORE DATA 2, in the original program stored the values of the variables 
specified in the COM statement. Since an array was not specified in this STORE DATA 
command, the subsequent LOAD DATA command cannot specify an array either. 


Notice that the COM statement used for the LOAD DATA command need not specify 
the same variable names as the COM statement that is used with the corresponding 
STORE DATA command. But simple variables should correspond to simple variables, 
arrays should correspond to arrays of the same size, split-precision arrays should 


correspond to split-precision arrays, etc. 
(Continued) 
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——-~—— For Advanced Programmers 


The LIST command gives totally different results when executed both before and after a 
program is run: 


@ Prior to running a program 


— without a COM statement, the file size needed to store the program on tape is 
determined by subtracting the LIST 9999 result from the total user memory. 
(Tape cassettes are discussed in Chapter 5.} 


— with a COM statement, the file size determined by the previous method minus 
the memory reserved for variables in the COM statement is the true file size 
needed to store the program. (Remember, each full-precision element in 
common has four words of memory allocated to it.) 


@ After running a program, when LIST 9999 is again executed, the available 
memory being displayed, subtracted from the total user memory, determines the 
approximate™ amount of memory needed to run this program. 





— 


The INIT ({nitialize} key resets the calculator to the state it was in immediately prior to 
program execution unless the program has a COM or DIM statement in it. Furthermore, 
program variables, not defined in a COM statement, are erased when the INIT key is 


pressed. 





If a program is executed and a LIST 9999 command is then executed, the approximate 
amount of memory needed to run the program !s determined by subtracting the number 
on the display from the total calculator memory. If this program has neither a COM nor 
a DIM statement in it, the file size needed to store the program on tape can then be 


determined if you press: 


ceca (e)(2)(9)(9) 


¢ 


and subtract the number on the display from the total calculator memory. 


(a-comne 


Other uses of the INIT key are discussed in the following section. 


* This is usually very close to the amount of memory actually needed. The difference exists because, during program 
execution, some memory is temporarily needed to run different parts of the program. 
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> ~~ ADDITIONAL COMMANDS ~~. 


The three commands discussed in this section provide the Model 30 with additional 
programming capabilities. Their uses are intended primarily for the advanced programmer. 


The INIT (Initialize) key was discussed in the previous section as a tool for determining 
program memory. Other uses for this key are discussed here. 





When C=? is pressed, it performs identically to the RUN command except that the 
program is not executed: 


® All variable values, aside from those specified in a COM statement, are erased. 


@ All normal programming modes are reset — angles are calculated in radians, 
Outputs appear in standard notation. 

@ Memory is reserved for all elements in a DIM statement. (Memory for the 
elements in a COM statement is immediately reserved when COM is entered into 
memory.} 

@ The memory reserved for DIM and COM statement elements can be accessed. 
(Although memory is reserved for COM before the INIT key is pressed, this 
portion of memory cannot be accessed until either the INIT or RUN command is 
given.) 


Since the INIT command performs this way, it offers the following additional feature 
when it is pressed: 
The programmer has the option of inputting values for some or all of his 
program variables before the program is run. After the required data [say, 
A(1)=6. ..A(12)=8, etc.] is keyed in, the program can be executed by 
pressing: 


=|) (Remember the RUN command would erase the 


values just assigned to the variables.} 


NOTE 


The INIT command is unnecessary if only simple variables are being input 
and if the program has neither a COM nor a DIM statement. 








PTAPE 


The PTAPE command allows the calculator to read in program statements from an input 
device, ASCII* character by ASCII character. Compatible devices include the -hp- 9863A 
Tape Reader, the -hp- 9869A Card Reader, the -hp- 2748A Optical Tape Reader, and the 
-hp- 11205A Serial Interface {with teletype). 


Just key in either PTAPE= or PTA= followed by the appropriate select code for the 
input device. Then press the EXECUTE key. 


if the device with the specified select code is not connected to the Model 30, the 
calculator waits until it is attached to complete the command. During this time the 
display will be blank. You can, of course, regain immediate control of the calculator by 
pressing the STOP key. 


7 ASCH {American Standard Code for Information Interchange} is understood by the Model 30. 





we 


During ‘the implementation of this command, each line being loaded into memory has its 
syntax checked; if a line is in error, it will be rejected — thus, only those lines with 
correct syntax are loaded into the calculator. To obtain a record of the rejected lines, it 
is necessary to put the calculator in the print-alf mode prior to executing the PTAPE 
command; in print-all mode, all rejected lines are printed. 


NOTE 


To punch information onto paper tape, use the LIST command as 
discussed earlier. 





The SEC (Secure) command has the capability of concealing program lines from potential 
users; that is, your program could be given to another person who could load it into the 
calculator from a cassette file and then run it — however, he would not be able to view 
particular program lines nor could he store the program on any other cassette file. (Tape 
cassettes are discussed in the next chapter.) 


Any attempt to display or list a secured program line results in the line number 
appearing, followed by an asterisk (*). 


The SEC command has the following three vartations: 


@ Al! program lines in memory can be secured if you press: 


(SJ(E)(e) 


@ All program fines beginning at a specified line number can be secured. For 
example, all program lines beginning at line 200 are secured if you press: 


Q00OH)||) 


@ Program lines can be selectively secured. For example, program lines 30 through 
60 are secured if you press: 


JYOOVVIOE) 
Since a program can have both secured and unsecured program lines, on a program listing 
only the secured lines appear with an asterisk following the line number. 


=) 
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When any part of a program is initially secured, the program can still be reproduced onto 
as many cassette files as necessary. However, once the program ts erased from memory, 
{even though it can be loaded back into memory) no portion of it can be reproduced 
onto any other files — not even an unsecured portion. 


NOTE 
When any program lines are secured, the entire calculator is in a ‘secured 


mode’. Therefore, after the secured program is stored away, the user 
should erase all of memory before inputting other programs — thus, 
avoiding ‘secured program’ errors. 
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: Chapter 5 
USING A TAPE CASSETTE 


The tape transport, built into the Model 30, provides the calculator with considerable 
flexibility as described in this chapter. Cassette commands are described beginning on 
page 5-4. 


> - > <>< THE TAPE CASSETTE -— oo oo 


The -hp- tape cassette used with the Model 30 is a precision unit, containing 300 feet of 
digital-quality, magnetic recording tape. These and other important characteristics make 
this tape cassette ideally suited for use with the calculator. 





SPECIFICATIONS 
Search Speed: Approximately 130 ft/min (search is bi-directional). 


Data Storage: More than 32,000 words can be recorded. 


————__—_—_. TT OTHER CASSETTES 


Although many other manufacturers’ tape cassettes will initially work with the Model 30, 
many of these products will not make reliable recordings. Also, since the use of some 
tape cassettes will actually damage the tape transport, you should be cautious about using 
other cassettes. 


For additional information on requirements for a tape cassette, contact your nearest -hp- 
Sales and Service Office: office locations are listed at the back of this book. 


> _ INSERTING TAPE CASSETTES 


To open the transport door, flick the switch on the upper right-hand corner of the 
calculator keyboard. Then insert the tape cassette by sliding it through the guide posts on 
the transport door; be sure the cassette is right-side up with the FRONT label! facing you. 
Finally, push the door closed. 


Whenever you want to remove the cassette from the transport, press the key "9 first. 
This fully rewinds the tape to clear-leader, thus shielding the recorded portion of the tape 
against dirt or damage. 





> »=PROTECTING CASSETTES 


The information recorded on a tape cassette can be protected (that is, further recording 
is not allowed) if you remove both tabs that are on top of the cassette — see Figure 5-1. 


If only the left tab is removed, the tape cassette is still essentially protected. But, in this 
case, it would still be possible for someone to insert the tape cassette backwards into the 
tape transport and record over previously recorded informaticn. 

{Continued) 
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THE TAPE CASSETTE 
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Figure 5-1. HP Tape Cassette 
STORING CASSETTES —<—_-—__._—!__—reow 


Since magnetic tapes are easily damaged, be sure to put each tape cassette in its plastic 
case when you have finished using it. Also, to keep the tape clean, be sure it is fully 
rewound (on clear-leader) before you remove it from the tape transport. 


As with most magnetic tape products, the information recorded in the tape cassette can 
be altered or destroyed if it is exposed to a strong magnetic field, such as one produced 
by a bulk tape eraser, a toy magnet, or a metal detection device (like the ones used in 
many airports). If you keep your tape cassettes in a metal container, such as a card index 
box, they will be protected from most magnetic fields. 


CLEANING THE TAPE HEAD ~<a» 


To ensure the reliability of tape cassette operations, it is recommended that the tape 
head be cleaned after every eight hours of cassette operations. Furthermore, it is always a 
good idea to clean the tape head before making important cassette recordings. 





Tape Head, 


Figure 5-2. Cleaning the Tape Head 


The tape head is easily cleaned as follows: 


1. Open the transport door and remove the tape cassette. 

2. Clean the tape head (see Figure 5-2) with a cotton applicator that has been dampened 
with head cleaning solution. Just wipe the top of the tape head a few times with the 
cotton applicator. Remove any other dust that has accumulated in the vicinity of the 
tape head. 

3. Close the transport door. It’s a good practice to keep the transport door closed 
whenever possible to prevent excess dust from accumulating in the transport. 


ms, 


oom™; 





In conclusion, special care must be taken to ensure reliable tape cassette operations. 
Always: . 
@ keep the transport door closed whenever possible to prevent dust from accumulating 
in the transport. 
@ clean the tape head after every eight hours of cassette operations and before making 
important cassette recordings. 
@ make duplicate (spare} tapes of important programs or data. 
® either remove the cassette from the transport or verify that the tape is positioned on 
clear-leader when switching the calculator ON. 
@ protect the tape cassette from scratches, dust and magnetic fields, like those associated 


with high-voltage electrical equipment. This includes the rear panels of input and 
output calculator devices. 


ig TAPE FILE STRUCTURE 


The tape is organized by files, which are established by the MARK command (MARK Is 
discussed beginning on page 5-6). The first file on a tape is file 8; subsequent files are 
identified as file 1, file 2, etc. Both the number of files and the lengths of the files (in 
words) can be designated in a MARK command. 


The tape structure is as follows: 


BOF BOF BOF BOF 
Control Control Control Control 
re ae Marker Marker 





File F Fi ‘ File 
al / 


Clear | BOT File : Clear 
ge 








a ye ey ee! 
File 8 File 1 File 2 File n+1 
thru 
File n 


Figure 5-3. Tape Structure 


Clear-Leader: Both the beginning and end of the tape have a clear-leader so 
that the calculator will know when the end of the tape is 
reached. 

BOT Slack: The beginning of tape (BOT) has a small slack (unused) area to 


ensure that file @ is read correctly during cassette operations. 


BOF Contro! Marker: The beginning of each file (BOF) has a control marker. This 
contro} marker separates consecutive files. 


File ID: The file identifier contains information like the file number, the 
file type {program, data, etc.), the absolute file size (in words), 
the current file size (number of words currently in use), etc. The 
13 words used in the file ID are additional to, and separate 
from, the words specified by the user in the MARK command. 


File Body: The file body is the portion of the file used to retain informa- 
tion. The absolute file body size is determined by the MARK 
command specifications. 


EOT Slack: The end of tape (EOT) has an unused area the size of which 
depends on the number of files marked and the length of each 
file. 
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>. 2. >> CASSETTE COMMANDS <-> > 


The cassette commands are briefly described below: 


@ MARK — establishes files with specified lengths. 

@ STORE — reproduces, onto tape, programs that are in memory. 

@ LOAD -— reproduces, into memory, programs that are on tape. 

@® LINK — works like LOAD but, in addition, it retains variables currently in 
memory. 

@ MERGE — inserts, between program lines currently in memory, program lines that 
are on tape. 

@ FIND — locates a specific tape fife. 

@ REWIND — rewinds the tape to clear-leader. 

@ STORE DATA — reproduces, onto tape, data that is in memory. 

@ LOAD DATA — reproduces, into memory, data that is on tape. 

@ STORE KEY — reproduces, onto tape, information that is on Special Function 


keys (see Chapter 6). 

@ LOAD KEY — reproduces, into the Special Function keys, information that is on 
tape. 

@ LOAD BIN — reproduces, into memory, specially written programs that are on 
tape. 

@ TLIST — prints information about each file. 


These commands are discussed individually beginning on page 5-6). 


PROGRAMMABILITY -@— 


All tape commands are programmable as well as being keyboard executable. The same 
syntax is used in either case. Of course, program statements are preceded by a line 
number and are entered into memory if the END OF LINE key is pressed; whereas 
keyboard commands are executed if the EXECUTE key is pressed. 


Three cassette commands have dedicated keys that can be used when executing the 
commands; f.e., “sore? tcm™, ewns;, However, if any of these commands are to be used in a 


program, the commands must be keyed in, letter by letter. 








SNA ee 


The terminology shown below appears in the command syntaxes: 


array name — the letter used to define the array (A through Z}; 

file — the number of the tape file; 

Ist line number -— the first line number designated; 

2nd line number — the second line number designated (it can appear only if the first 
line number is designated); 

length — the length of the designated files;* 

no. of files — the number of files designated.*. 


¥Can be @ constant, a variable, or an expression. 
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} The following conventions are also used: 
brackets [ ] — to indicate optional! items; 
coloring — to indicate that the colored ttem must appear as shown. 


Here’s an example using the complex version of the STORE command. Once you 
understand this syntax, you should have no trouble with any of the syntaxes. 


Syntax: 
STORE file[, 1st line number[, 2nd tine number] ] 


Let’s look at the syntax, step-by-step, from left to right: 


1. The word, STORE, is necessary to identify the command. 

2. The ‘file’ number is needed to specify the file that will record the program. 

3. The ‘Ist line number’ is optional; but if it is specified, then a comma is needed to 
separate the ‘file’ from the ‘1st line number’. 


4. The ‘2nd line number’ is optional, too; but for it to be specified, the ‘1st line 
number’ must also be specified; if both are specified, then a comma is needed to 
separate the two items. 


Since the brackets are nested in this command, for the most deeply nested item to be 
specified, all other items must be specified, too. If, however, the brackets had appeared 


as: 
) mann manner | ) [wee] 





then this dependency between items would not exist; that is, the information within the 
second bracket could be specified without having the other bracketed information 


specified. 


The syntax requirements for each command are shown individually in the tape command 
discussions and are shown all together on page 5-25. 


weet ee 
a 
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The MARK command is used to establish tape files. Both the number of files to be 
established and the lengths of the files (in words) are specified in this command. 


Syntax: 

MARK no. of files , tength 
When the MARK command is executed, files are marked beginning at the tape’s current 
location. If the tape is rewound, the marking begins at file @; but if the tape is located 
at, say, file 3, then the marking begins at file 3. 


The tape can be located at any file if the FIND command (see page 5-16) is used. 





MARKING NEW TAPES 


To mark a new tape, first be sure that the tape is rewound by pressing the key, 
REWIND. Then mark the number of files you want with the lengths that you want. 


If you want, say. three files marked, each with 500 word lengths, press: 


OOQOOQOOOOOH}|}] 


In about 30 seconds the symbol, +, appears on the display, indicating that the operation 
is completed. File @, file 1, and file 2 have now been marked. Each of these files can 
record information up to 500 words in length. 


= Or mrt 


An extra file, file 3, is also marked. There are two reasons for the extra file: 


@ The BOF (beginning of file) control marker (see Figure 5-3, page 5-3) for each 
file serves as an EOF {end of file) control marker for the previous file. 


@ ina FIND command, the extra file can be accessed: so new files can be marked 
beginning at this point. (Had the extra file not been marked, another MARK 
command would have had to remark file 2.) 


The extra file should not be used to record information, however, since any information 
in this file will be erased when more files are marked. 


A new tape can also be marked with several files of varying lengths if successive MARK 
commands are used. First, be sure that the tape is rewound. Then to mark, say, two files 
with 300 word lengths, four files with 1000 word lengths, and one file with a 2500 word 
length, execute the following: 


1. MARK 2,300: !n about 30 seconds file @, file 1, and the extra file (file 2) are 
marked. Then if you execute: 


2. MARK 4,1000: In about 60 seconds file 2, file 3, file 4, file 5, and the extra file 
(file 6) are marked. This MARK command takes considerably longer to execute since 
much more tape is marked. Then if you execute: 


3. MARK 1,2500:7 In about 70 seconds file 6 and the extra file (file 7) are marked. 


t Of course, the absolute size of a recording is limited by the memory size of the calculator: so, if the memory size of 
your calculator is 1760 words, it would be pointiess to mark a file with 6 tength of 2560 words. 


The pictorial below illustrates these MARK commands: 
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Mark 2, 300 Mark 4, 1000 Mark 1, 2500 





Figure 5-4. Marking Successive Files 


Notice that the extra file marked by each command is temporary, as indicated by the 
dotted file line. The extra file is replaced by a new file each time another MARK 
command is executed. {n this case, file 7 is the remaining extra file. Additional MARK 
commands can be executed from this point. 


MARKING A USED TAPE 


The MARK command is the same for both new and used tapes. But for a used tape, it ts 
necessary to position the tape at the file where the marking is to begin. This ts 
accomplished by using the FIND command (discussed on page 5-16). 


If the tape is still marked as shown on Figure 5-4 in the previous section, file 5 is located 


HOWE 


You can now mark files beginning at this point. If, however, you wish to retain any 
recorded information that is on file 5 or file 6, then a FIND 7 command is preferable. 
This focates the tape at the extra file, file 7; new files can be marked at this point 
without destroying any previously recorded information (unless you have made the 
mistake of recording on the extra file}. 


Acoma 


NOTE 
Whenever marking a used tape, begin marking at a point from which you 


do not need any of the previously recorded information. For the contents 
of all previously used files from this point onward will be either destroyed 
or altered (even if only a small portion of the tape is re-marked). 





If you are uncertain of the number of marked files, the lengths of the files, the 
information in the files, etc., use the TL!IST command as discussed on page 5-23, to 


identify your tape files. 
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The STORE command is used to record, onto tape, programs that are in memory. The 
contents of memory are not altered by this command. If you want to record all program 
lines that are in mainline memory=, the syntax is simply: 


STORE [file] 
The file specification is optional; for if no file is specified, file @ is assumed. Since file @ 
is the most easily accessible file, it is often convenient to use file @ as a ‘scratch-pad’ 
file. = 


So if you press: 


All program lines in memory are recorded in file @. 


RPACOMaM 


Or if you press: 
=@(/) All program lines in memory are recorded in file 5. 


The LOAD, LINK, and MERGE commands (discussed later) also assume file & if no file ( 
is specified. 


| For more sophisticated applications, the syntax is: 
STORE file [, Ist line number [, 2nd tine number] ] 


| Ist line number: The first line number specified is the lowest-numbered line in memory 
that you want recorded. All higher-numbered lines are also recorded unless the 2nd line 

| number is also specified. 

2nd line number: The second line number specified is the highest-numbered line in 

memory that you want recorded. All lines between the specified line numbers are also 

recorded. 


If the cassette is not protected (as discussed on page 5-1), a program can be stored in any 
file that has a length greater than or equal to the size of the program — in words. 





When a program is stored into a tape file, everything previously in that file is erased. 


) ———————_—— Examples 


For the following examples, assume lines 10, 20, 30, ... 100 are in memory. If so the 
following commands could be executed: 


STORE 3: All program fines are recorded in file 3. ( 


+ The term. ‘mainline memory’, is used here to emphasize that programs on Special Function keys are not stored 
unless you are in the KEY mode (see page 6-7). 


TA ‘scratch-pad’ file is used to retain temporary information. 





) > STORE 5, 40: All program lines, beginning at line 40, are recorded in file 5. (To 
specify the 1st line number, you must also specify the file.) 


STORE 8, 40: All program lines, beginning at line 40, are recorded in file g. (Even 
though file @ is used here, it must be designated since the 1st line number is 
designated.) 


STORE 2, 20, 80: All program lines, from line 20 through line 80, are recorded in 
file 2. (To specify the 2nd line number, you must also specify the 1st line number.) 


STORE X+3, 60: All program lines, beginning at line 60, are recorded in the file 
indicated by the expression, X+3. So if X=4, the program lines are recorded in file 7. 









NOTE 


Do not confuse the STORE key with the LOAD key. If, by mistake, you 
execute a LOAD command instead of STORE, you could erase the 
program in memory. Likewise, if, by mistake, you execute a STORE 
command instead of LOAD, you could erase the program on tape. 
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The LOAD command takes programs that are stored on tape and reproduces them inta 
the calculator memory. 


To replace the information in memory by the program lines in a specific file, you can use 
the following syntax: 


LOAD [file] 
The file specification is optional; if no file is specified, file @ is assured. 


So if you press: 


The program lines from file @ are loaded into memory. Information previously 
in memory is erased. 


Or if you press: 


(0) 


For more sophisticated applications, the syntax is: 
LOAD file [, 1st line number [, 2nd line number] ] 


The program lines from file 4 are loaded into memory. Information 
previously in memory is erased. 


ax4MCOmMm 


Whenever the LOAD command is executed, all program lines in the specified tape file are 
reproduced into memory. All program lines previously in memory are erased unless the 
1st line number is specified. 


Whenever the 1st line number is specified, the reproduced program lines are renumbered 
with the beginning line number corresponding to the specified 1st line number. (The 
spacing between consecutive line numbers remains the same; furthermore, statements, like 
GO TO 30,* are appropriately renumbered.) Program lines previously in memory, with 
line numbers lower than the 1st line number, are retained; all other lines previously in 
memory are erased. 


In the calculator mode (after the program is loaded into memory): 


@ If the 2nd line number is not specified, the calculator halts. 
e@ lf the 2nd line number is specified, program execution begins at this fine number. 


In the programming mode {in this case, specifically after the LOAD command is executed 
during program execution): 


@ If the 2nd line number is not specified, program execution is ‘restarted’ either 
with: 


— the program line immediately following the LOAD command in the original 
program, or with 


+ A GOTO statement in a tape file must refer to a line in the file for the renumbering to be successful: if the GOTO 
Statement on tape refers to a program line currently in memory. an error will occur when the renumbering is 
attempted. 





coo 





but if, instead, you press: 
OVYOO® 
To delete just one program line, say, line 82, you can press: 


OPYOVOVIM® 


But there is an easier way to delete one line without using the DEL command. Just 
press: 


esc omam 


| 
| All program lines, beginning at line 22, are deleted. 


BCom wm 


and line 82 ts deleted. Any time a line number 


(8)(2)(-=™ ) is keyed in, followed immediately by END OF 


LINE, the specified line is erased from memory. 


The SCRATCH key was discussed on page 2-14. The SCRATCH commands that are most 
useful in programming are as follows: 





mama All variables and program lines are erased from mainline memory. (Information 
on Special Function keys, see Chapter 6, is not affected.) 


All of memory its erased as in turning the power off then on again. Before 
a large program is entered into memory, this command ensures that the 
maximum amount of memory is available. 


=0) 


Rralom a 
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~~ PROGRAMMING CHECKS ~+—2—2—> 


The techniques discussed in this section allow the programmer to make various checks 
during program execution to ensure that the program ts operating correctly. 





ars com 


The TRACE command is used to follow the order of statement execution in a program. 
If the TRACE key is pressed during program execution, the program line numbers are 
printed in the order in which they are accessed; if the NORMAL key is then pressed 
while the program is still running, the TRACE command is nullified. So during program 
execution, both TRACE and NORMAL are ‘immediate execute’ keys. 


{f the program is not currently running, the TRACE command has the following 
capabilities. 


@ |t can be set to trace the order of statement execution when the program is again 


run. Just press: 
q 


@ it can be set to trace from a specific line number, if the lowest line number to be 
traced is specified. For instance, with the following command, all lines numbered 
80 and higher will be traced when the program is again run: 


00)! 


@ It can be set to trace groups of line numbers, if both the lowest and the highest 
line numbers to be traced are specified. For instance, with the following 
command, all lines numbered 120 through 160 will be traced when the program is 
again run: 


aQOOOOOO|! 


While the program is running, any of these TRACE commands are immediately nullified 
if the NORMAL key is pressed. But if the program has been halted with TRACE still in 
effect, TRACE is nullified if you press: 


i 





If 2 program is not running, it can be continued one line at a time if the STEP command 
is used. STEP is always an ‘immediate execute’ key. As soon as it is pressed, the line 
designated by the internal program line counter is executed, then the program halts again. 
When the program halts, the current position of the program line counter is displayed; 
that is, if =@- is pressed again, the line specified in the display will be executed. 


OT, 
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For example, suppose the following program is run: 
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This program halts after line 60, the STOP statement, is executed. So the program line 
counter is positioned at line 70. Jf = is then pressed, only line 70 is executed. Each 
time Gee is pressed, only the line designated by the program line counter jis executed. An 
entire program can be run this way. (The next section, Checking a Halted Program, shows 
why it can be desirable to execute a program step-by-step.) 








For Advanced Programmers 


In the previous program, after line 200 is executed, the program line counter reverts to 
line 10. If the STEP command (or the CONT command) is then used to continue 
program execution at line 10, the program does not go through an initializing phase; that 
is, variables retain their current values, operating modes {like calculating angles in radians) 
are not reset, etc. With the RUN command, this initializing phase is automatic. So, in this 
example, if STEP is used after line 200 is executed, the angle, Y, is calculated in degrees 


since line 70 previously set this mode. 


gS CHECKING A HALTED PROGRAM 


Various operations can be performed on a halted program: 


@ Values of variables can be checked merely by keying in the variable name, 
followed by EXECUTE. 
@ Values of variables can be assigned or changed if commands like A=7 are 
executed, 
@ Many program statements can be keyed in as executable commands; that is, 
without line numbers and followed by the EXECUTE key: 
PRINT statements 
WRITE statements ¢ to immediately output specified information. 
DISP statements 
GOTO statements to reset the program line counter to a specified 
GOTO with OF statements } line. 
RESTORE statement — to reset the data pointer to the first data element. 
@ Any keyboard command can be executed: degrees, grads, radians, fixed n, float n, 
standard, etc. Also, arithmetic operations can be performed. 


{continued} 
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(continued} 


tf the halted program is continued with either the CONT or the STEP command, any of 
the previously mentioned operations that affect the program execution remain intact. For 
instance: values of variables that were changed retain their new values; a GOTO command 
causes the program to continue at the specified tine number; a DEG command causes the 
program to calculate angles in degrees; etc. 


lf, however, the halted program is restarted with a RUN command, then the program is 
initialized and the calculator reverts to all standard operating modes. 


Furthermore, if any program lines are inserted, deleted, or edited while the program is 
halted, the program line counter is repositioned at the lowest numbered line in memory. 


~>———~@—e—@~ CALCULATOR MEMORY ~—oo—-o > 


In the Model 30, the total amount of user memory is expressed in ‘words’. (For the 
computer oriented, there are 16 bits — two bytes — per word.) The basic calculator (with 
no memory options) has 1760 words of available memory. 


Program statements take up a variable number of words with as few as three words 
allocated in some statements, such as STOP and END. Methods for determining the 
available memory are discussed next. 





As mentioned earlier in this chapter, the LIST command always displays the available 
user memory after it performs a program listing. To determine the maximum amount of 
user memory, it is necessary first to erase everything in memory (thus making all of 
memory available) and then to perform a LIST command. So if you press: 


=O) followed by mn(s}(s)(9)}(9) 


the number that appears on the display is the total calculator memory. (Any memory 
options that have been installed are also included in this number.) 









SOM em 


4 


( 


lf information is in memory and you want to determine how much memory is still 
available, it is generally easiest to press: 


ar) 9 es) 
(2)(2) (2) u 





AAG oenm 


The number that immediately appears on the display is the available memory. Whenever 
the number specified in the LIST command is greater than the largest line number 
currently in memory, no program lines are listed and the available memory is immediate- 
ly displayed. So by using LIST 9999, you need not be concerned about the line numbers 
currently in memory. For no line number greater than 9999 can be specified. 
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{continued} 





DEG, GRAD, RAD 


{n a program, angles are calculated in radians unless either degrees or grads have been 
specified in a prior program statement. If radians are then specified in a later program 
statement, angles will again be calculated in radians. 








Examples 
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In line 10, X is calculated in radians; in line 30, Y is calculated in degrees; in line 50, Z 
is calculated in grads; in line 70, X1 is calculated in radians. The printout for X, Y, Z, 


and X11 Is: 





When the calculator is initialized or another program is run, the calculator reverts both to 
standard notation and to radians. 


PROGRAMMABLE TAPE COMMANDS ~—\-—__—--_ 7". 


All tape cassette commands are programmable. These commands are discussed individu- 
ally in Chapter 5. 


~~» —~o—e FLOWCHARTING TECHNIQUES <—..—> 


{f you are a beginning programmer, you may be interested in knowing some of the 
techniques available that allow you to more easily advance from a conceptual stage in a f 


programming task to a finalized stage. 


Flowcharts, which logically pictorialize the solution to a programming task, are valuable 
programming tools. They are often drawn long before the actual program statements are 


written. 
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While 4lowcharting your problem, you might change or simplify your approach, see a 
flaw in your logic, etc. After several attempts, you should have a workable flowchart and, 
once you do, your programming task is greatly reduced. 


Any flowchart that you draw is useful; but a few basic flowcharting conventions are 
described briefly here. Terminai (that is, starting or ending) activities are represented by 
ovals. Arrows, indicate the order of operations between the terminals. Most calculator 
Operations are represented by rectangles. A diamond represents a decision point. If the 
information within the diamond is computed as ‘YES’, the logical flow continues in one 
direction; if it is computed as ‘NO’, the logical flow continues in another direction. 


For your convenience, in the following example we have labeled each flowcharting 


Operation with the corresponding program tine number. As can be seen, once the 
flowchart is finalized, the program can be written relatively easily. 


RUN EXECUTE 








20 
PRINT A/T 
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Legend 


brackets [ ] items enclosed within brackets are optional. 


coloring — colored items must appear as shown. 

character — a letter, a number or a symbol. 

constant — a number within the range of the calculator. 

expression — aconstant [like 16.4], a variable [like B or D(6)] or an expression 
[like 8*At2 or 6=A]. 

letter — an alphabetic character from A through Z. 

line number — an integer from 1 through 9999. 

local variabie — a simple variable defined only in relation to the function. 

n — an integer from @ through 11. 

select code — an integer from 1 through 15. 

text — a series of characters enclosed within quotation marks. 

variable — a simple variable [like B or B7] or an array variable [like F(Q)]. 


Ali programming statements must be preceded by a line number. 


i 


variable = expression or LET variable = expression 
Assignment statement; assigns variable a value. 


COM variable [, variable - - - , variable] 
Reserves memory for the specified variables and allows data to be transferred from 
one program to another. Must be both the first statement entered and the 


lowest-numbered statement. 


DATA constant [, constant - - - , constant] 
Specifies data for READ statement variables. 


DEF EN letter (local variable) = expression or DEF FN letter (focal variable) 
Defines a function in one line (first syntax) or in several lines (second syntax); in the 
latter case, a RETURN statement is also needed. 


DIM variable [, variable - - -, variable] 
Reserves memory for the specified variables when the calculator is initialized. 


DISP [any combination of text and expressions] 
Allows text and values to be output on the Model 30 display; follows the same rules 


as the PRINT statement. 


END 
Terminates program execution and resets the program line counter to the lowest- 
numbered statement in memory. 


FOR simple variable = expression TO expression [STEP expression] 
Executes the program lines between FOR and the corresponding NEXT statement a 
designated number of times; each time the loop is executed, the simple variable is 
incremented by 1, unless STEP is specified. 


( 
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,) FORMAT any combination of text or other specifications 
Gives output specifications to the WRITE statement that referenced it; specifications 
: can be: Fw.d (for fixed-point format}, Ew.d (for exponential format), X (for a 
character space), / (for a carriage return—line feed), 8 (for special ASCII characters): 
any specification can be repeated (say, 6Fw.d); specifications must be separated by 
commas. 


GOSUB line number 
Begins executing the subroutine at the specified line number; must have correspond- 


ing RETURN statement. 


GOSUB expression OF line number [, line number - - -, fine number] 
Begins executing the subroutine at the first line number if the expression is rounded 
to 1, at the second line number if the expression is rounded to 2, etc.; must have 
corresponding RETURN statement. 


GOTO line number 
Transfers program execution to the specified line number. 


GOTO expression OF fine number [, line number - + -, line number] 
Transfers program execution to the first jine number if the expression is rounded to 
1, to the second line number if the expression is rounded to 2, etc. 


IF expression THEN line number 
Expression is logically evaluated; if it is evaluated as ‘true’, program execution is 


transferred to the specified tine number. 


INPUT variable [, variable - - -, variable] 
) Allows values to be assigned to the variables, from the Model 30 keyboard, during 
program execution, when a ‘?’ appears on the display. 


LET variable = expression or variable = expression 
Assignment statement; assigns variable a value. 


NEXT simple variable 
Marks the end of the corresponding FOR Soop. 


PRINT [any combination of text and expressions] 
Allows text and values to be output on the primary printer; successive expressions 
must be separated either by commas (for maximum spacing between successive 
outputs) or by semicolons (for minimum spacing between successive outputs); if no 
parameters follow PRINT, the printer performs a carriage return—line feed; para- 
meters can also include: TAB expression — so that the following parameter is output 
beginning at the absolute character position (from @ through 71) specified by TAB. 


READ variable [, variable - - -, variable] 
Reads, from the DATA statement (beginning at the currect data pointer position), 
values for the specified variables. 


REM [any combination of characters] 
Inserts non-executable remarks in a program. 


RESTORE [line number} 
Resets data pointer (see READ and DATA) to the first constant in the lowest- 


numbered DATA statement if the line number is not specified: or resets the data 
pointer to the first constant in the DATA statement with the specified line number. 


}- RETURN [expression] 

| With no expression specified, RETURN is the subroutine exit, transferring program 
execution to the line following the GOSUB statement; if an expression is specified, 
RETURN is the multiple-line function exit, transferring the value of the function to 


the statement that called it (see DEF FN}. 
(Continued) 
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{Continued) 


STOP 
Terminates program execution but, unlike END, it retains the current position of the 


program line counter. 


WAIT expression 
Causes the calculator to halt the specified number of milliseconds; the delay can vary 


between @ and 32767 milliseconds. 


WRITE (select code, [*] or [line number]}) [any combination of text and expressions] 
With the ‘’«’ specification, WRITE is like the PRINT statement except that any 
printer can be specified by select code; with the line number specification, the 
parameters are output according to the specifications in the corresponding FORMAT 
statement. 


{DEG] or [GRAD] or [RAD] 
Specifies units for calculating angles; if not specified, RAD is assumed. 


[FIXED nj] or [FLOAT n] or [STANDARD] 
Specifies numerical output form for PRINT and DISP statements; if not specified, 


STANDARD is assumed. 
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; Chapter 4 
PROGRAMMING-RELATED INFORMATION 


In Chapter 3, general programming techniques were discussed along with the BASIC 
language statements. In this chapter, most of the topics discussed emphasize the ease of 
programming the Model 30. Topics include: 


~—>—*> STANDARD PROGRAMMING COMMANDS -~—— 


The following keys and commands were discussed briefly in Chapter 3: 


@ (som ) which enters program lines into memory. 


Standard programming commands 
Time-saving commands 
Program-viewing and editing techniques 
Programming checks 

Calculator memory. 


STANDARD 


oO 
2¢ 
zz 
== 
ce 
oF 
Oo 
cv 
a 





e («=») ql which runs the lowest-numbered program in memory. 


which halts a program that is running unless the program is waiting at an 
INPUT statement. 


© (me) which halts a program that is waiting at an INPUT statement. 


J : which continues a program that was previously halted; if the program was 
© [cont] 


halted by either a STOP command or a STOP statement, the program 
continues from the line mumber where it was halted. Otherwise, it 
continues at the lowest-numbered fine in memory. 


RUN, STOP, and CONT have additional capabilities as discussed next. 





* 
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(continued) 





If there are several programs in memory, any of these programs can be executed by using 
the RUN command. For instance: 


if IMPUT A.B 

2H PRINT Atet+ete 
Program 1 ; 

98 END 

i@@ INPUT CoD 

114 PRINT Ct2-Dte 
Program +2 K 

128 END 

208 INPUT Ns¥ 

219 PRINT SORCEtEZ+yt2) 
Program #3 : ( 

298 ENT 


Pressing: 
oi executes program #1. 


Pressing: 


executes program =3, beginning at line number 200. 


HOO) 


Or pressing: 


SOO 


executes program +2, beginning at line number 100. 


Whenever the RUN command is executed, variables that were assigned values in the 
previous program become undefined (unless both programs have a COM statement}. For 


instance: 


it 1 

i Meise 

as v4 i ss 
[Se m1 
ha tri ; 
oot Lie 
7Fa 0) Thi T 

a te bet BE 
See BL ee Se 

2 merer, 
‘a oH & Pate 
ye itt 





ITERATE FRLYUV Rg Sep net y= 8 CS nm ne etme nee eee eee eek SMV AE IE Re BRR ke fre ameame ns menrens 


If you press: 
— 


But then if you press: 


| Lines 10 and 20 are executed and the variable X is set equal to 15. 


ncOomam 


G 





The calculator tries to execute line 30 but cannot since the 
variable X is undefined. So error 40 results. (The CONT 
command, discussed on page 4-4, could have been used 


instead.) 


Besides being used to halt a program that is currently running (see page 4-1}, the STOP 
command has another variation. For instance, if the following program is in memory: 
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and the following keys are pressed: 


IOS (e) 


If the program is subsequently run without having any program lines edited, the program 
will halt at line 150 (that is, line 150 is not executed). If the program is then continued 
or re-run, and line 150 is again encountered, the program will once again halt there. 


Salon we 


Either one or two line numbers can be specified in a STOP command. For instance, the 
following keys could be pressed: 


GO09O08H)} 


If the previous program is then run, it will halt at line 90. if it ts then continued from 
this point, it will subsequently halt at line 150. When either of these two lines is 
encountered, the program halts. 


ANG Am em 


To have the program revert to normal execution when it is again run, either press: 


= 


or edit any portion of the program. 
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(continued) 


x= 


When the keys — CONT EXECUTE — are pressed, program execution continues from the 
point where it was previously halted, if the program was previously halted by either a 
STOP command or a STOP statement. Otherwise, it continues at the lowest-numbered 
line in memory. 


Unlike the RUN command, which erases the values of variables in memory, the CONT 
command does not affect variables. 


Like the RUN command, which can run a program beginning at a specified line number, 
the CONT command can continue program execution at a specified line number. 


For instance, pressing: 


can (2)(0)(0) 


would continue a program’s execution at line 200 without affecting any of the variables 
previously defined. 
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~~~. TIME-SAVING COMMANDS ooo 


The following two commands simplify program line numbering. 





Each program tine must be preceded by a line number. lf several program lines need to 
be keyed in, the AUTO= (Automatic Line Numbering) command can be used to simplify 


the task. By pressing: 


The first line number, 10, immediately appears on the display. After this line is 
keyed in, successive line numbers will be: 20, 30, 40...; that is, a spacing of 
10 between consecutive line numbers. 


The AUTO= command can specify the beginning !ine number to appear on the display. If 
it does, it can also specify the spacing between line numbers. The first number specified 
is the beginning line number; the second number specified is the spacing. If no spacing is 
specified, a spacing of 10 is always assumed. Here are some examples: 


an(s)(0) 


( 
| The line numbering would be: 30, 40, 50, 60,... 


mac am ee 


ca (s ) (o)(+} |} The line numbering would be: 50, 55, 60, 65,...- 


mat 


; am, 


ES TREE VIF D mstR gti oe oo ee stones em RTE en ee mn ne et canner nie am Lem T OU etm amie cree came mene rne ne tee 


omnmm 


is identical to cam | | 
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During automatic line numbering, after one line is entered into memory, the next line 
number appears on the display. If the line numbering sequence is somehow altered (say, 
the CLEAR key is pressed), automatic line numbering ceases. In a case such as this, to 
reinstate automatic line numbering at a specific line number, just use the techniques 
previously discussed. 


ate 


During automatic line numbering, the DELETE LiNE key can be pressed instead of 
CLEAR. DELETE LINE performs the same function as CLEAR without eliminating 
automatic line numbering (see DELETE LINE, page 4-8). 


Occasionally, it is necessary to change the spacing between line numbers to allow for the 
insertion of additional program lines. The REN (Renumber) commanc provides this 


capability. 


With this command, all program lines in memory are renumbered. Furthermore, program 
lines referenced in statements (e.g., GOTO 20) are appropriately renumbered. Here are 
some examples of the REN command: 


If these are the program lines in memory: 
1,2, 5,6, 7, 8, 111, 112, 113, 114 


and you press: 


(R)(e) () The program fines are renumbered. The towest line number is 10 with 
a spacing of 10 between successive line numbers. 


The ten lines in memory are now numbered: 
10, 20, 30, 40, ... 100 


As in the AUTO= command, both the lowest line number and the spacing between 
consecutive line numbers can be specified. The first number specified is the beginning tine 
number; the second number specified is the spacing. If no spacing is specified, a spacing 
of 10 is always assumed. Here are some examples: 


(R) (e}(n) (3) The new line numbering would be: 3, 13, 23, 33, ... 
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The commands discussed in this section allow the programmer to view individual program 
statements or to view a series of program statements. 


Any program line in memory can be brought to the display if the FETCH command is 
used. If line 65 is in memory, you can display it by pressing: 


{rercn] ©) Any line can be specified in this manner. 


If the tine number specified by the FETCH command is not in memory, then the next 
higher-numbered line is displayed; if there are no lines numbered higher than the one 
specified, then the highest-numbered line in memory is displayed. 





The highest-numbered line in memory is always displayed if you press: 


a=(s)(9)(9)(e) 


The lowest-numbered line in memory is always displayed if you press: 


==(I| 


Every program line in memory can be viewed by using these keys. 


Rat om 


Each time —*3 is pressed, the next higher-numbered program line is displayed. Each time 
Ct is pressed, the next lower-numbered program line is displayed. 


When either of these keys is pressed, the first line number displayed depends on the last 
line number that was accessed. For example, if the following lines are in memory: 

10, 20, 30, 40, 50 
and the FETCH command is used to access tine 30: 


Then if C47 is pressed, tine 40 is displayed; whereas had —4— been pressed, 
line 20 would have been displayed. 





But if a program has just been run: 
Pressing <#=, displays the fowest-numbered line in memory; whereas 


an 


pressing C#—, displays the highest-numbered line in memory. 


If either of these keys is held down for about two seconds, the operation of the key is 
rapidly repeated. 





( 


in’ 





ee Sf we hie 
. 
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With the LIST command, program lines can be output on any compatible printer or 
paper tape device. Merely specify the select code of the appropriate device; for example: 


7 P fe) All the program lines currently in memory would be output in 
Coe) (ee og i 8 | _ line number order on the device with select code =8. The ‘=’ 
a \ 


; (number sign) is necessary in this case. 


RAcOmMm 


However, if you want to output on the primary printer (select code +15), just press: 


Select code =15 is assumed tf no select code is specified. So, in this case, all 


Cost) program lines are output on the primary printer. 


ASCOMmaS 


Program lines can be selectively output by using the LIST command. For example, if 
lines 1 through 1G0 are in memory and you press: 


ca (4) (0) 
Or if you press: 


c=(s)(-) (1) ol Program lines 5 through 18 are printed. 


If only one line number is specified, as in the first case, only the lower boundary of the 
listing is specified. But if two line numbers are specified (separated by commas), as in the 
second case, both the lower and the upper boundaries of the listing are specified. 


All program fines, numbered 40 and higher, are printed. 


mstcom ae 


com hm 


a 


A number always appears on the display after a LIST command is executed. This number 
is the available calculator memory. The calculator memory is discussed beginning on page 
4-12. 
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>>> PROGRAM EDITING 222+ 


Programs can be easily modified if the keys and commands, discussed in this section, are 
used, 





These three keys can be used in the programming mode in the same way that they are 
used in the keyboard mode (see page 2-10). Any time a program line appears in the 
display, it can be modified by using these keys. After the line is appropriately corrected, 
press the END OF LINE key to put the corrected version of the line into memory. 


NOTE 
It makes no difference where the blinking indicator is positioned when the 


END OF LINE key is pressed. Regardless of the position, the entire 
program line is entered into memory. 








This key also can be used in the programming mode in the same way that it is used in 
the calculator mode. If you try to enter a program line into memory and an error 
message appears on the display, press ™«. The line you just keyed in is returned to the 
display. Appropriate corrections can then be made and the line can be entered into 
memory by pressing the END OF LINE key. 


During keyboard operations, if either the CLEAR key or the DELETE LINE key is 
pressed, the display fs erased. The difference between the two keys is evident if a 
program line that is stored in memory is displayed, With the symbol, +, displayed at the 
end of the program line, the DELETE LINE key can be pressed both to clear the display 
and to erase the program line from memory; pressing the CLEAR key clears the display 


only. 





Whenever you are displaying a line previously entered into memory, (e.g., 10 A=6#) to 
erase it from memory, just press the DELETE LINE key. 


As mentioned with the AUTO+ command, pressing the DELETE LINE key during 
automatic line numbering operations does not affect the automatic line numbering; it 
merely erases the rest of the display. However, pressing the CLEAR key erases the entire 
display, including the automatic line numbering. 





DEL 


The DEL (Delete} command can erase any number of consecutive lines from memory. If 
fines 1 through 100 are in memory, lines 22 through 35 can be deleted by pressing: 


OOOODOO|. 


* 


ele aS aan NI a 
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Since the result of 6*7 ts positive, a ‘1’ ts returned; and since the result of —6*7 
is negative, a ‘—1‘ is returned. 


BOOS 
DOOOOOOHO 


For the square root of a negative number is an ‘imaginary’ number. 





SL TRIGONOMETRIC FUNCTIONS 


The following trigonometric functions can be executed: 


SIN (expression) which determines the sine of an expression. 

COS (expression) which determines the cosine of an expression. 
TAN (expression) which determines the tangent of an expression. 
ATN (expression) which determines the arctangent of an expression. 


The angle is always assumed to be in radians, unless otherwise stated. However, the angle 
can be expressed in any of the following three ways: 


DEG which calculates angles in degrees. 
GRAD which calculates angles in grads. 
RAD ~ which calculates angles in radians. 


When one of these three forms is specified, all calculations assume the specified form. 


To revert to one of the other two forms, it is necessary to execute the destred 
mnemonic. 


Then, if all the memory is erased or if the calculator is initialized (see page 4-14), radians 
are once again assumed. 


The value of z can be obtained if you key in: 


(P) (1) When an expression encounters this, 3.14159265360 is assumed. 


(Continued) 


Yt Like the mathematical functions, it is generally wise to separate the expression by parentheses although parentheses 


are optional if the expression is either a positive constant, a variable, or another function. 


ee ee cee eee Teed 
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FUNCTIONS ©-o ooo om 


{Continued} 


Here are some examples; execute the following key sequences: 


QOOOQ CaN) 
OWOMOOOVOWO 


The last result approximates positive infinity. Now to compute angles in degrees, execute: 








The arcsine and arccosine functions are not directly obtainable on the Mode! 30. 


However, they can be easily obtained by using the following formulas — where x is the 
point at which the function is evaluated. 


Arcsine x=ATN(x/SOR(1—xt2)) 
Arccosine x=ATN(SOR(1—xt2)/x) 


Here’s an example; with the calculator still in degrees, the arcsine of .5 can be 
determined if you execute: 


MONMOOOQOOOHOOOOOOVOW 
J 





MATHEMATICAL HIERARCHY 





When functions are included in the arithmetic hierarchy*, they have the highest 
precedence. So the order of execution is as follows: 


1. Functions 

2. Exponentiation 

3. Multiplication, Division 
4. Addition, Subtraction 


highest precedence 


lowest precedence 
All other rules affecting the order of execution remain the same. 


¥ The arithmetic hierarchy was presented on page 2-6. 
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a ~> ~~. ———— LOGICAL EVALUATION ~«o—e_2_> 


In logical evaluation, expressions* can be compared by using relational operators and/or 
logical operators. If the comparison is ‘true’, the value ‘1’ is returned; if the comparison 
is ‘false’, the value ‘O’ is returned. 





RELATIONAL OPERATORS 


These operators are used to determine the logica! relationship between two expressions. 
They are as follows: 


equality = 







inequality #or<>?* 

greater than > 

less than < z 

greater than or equal to >= ae 

less than or equal to <= 82 
> 


The equals sign is also used in assignment statements as shown on page 2-9. In 

assignment statements, the variable is to the left of the equals sign and the value to be 

assigned to this variable is to the right of the equals sign. If the equals sign is used in 
ie such a way that it might be either an assignment or relational operator, the Mode! 30 
assumes it is an assignment operator. 


) Here are a few examples using relational operators: 


First let’s assign values to the variables A, B, C, and D. Execute: 


OG) bt 
(OC) toe ae 
SG) fs ee 
OG) Cz 


Now execute these logical expressions: 


ey ey, eed 


A<B which is true, so 1 is displayed. 
B<A which is false, so 9 is displayed. 


B#C which is true, so 1 is displayed. 

C#D which is false, so @ is displayed. 

3=C which is true, so 1 is displayed. 

4= which is false, so @ ts displayed. 

A=4 which is an assignment statement and not a logical statement; so A is 
/®. assigned the value of 4. 
) : Relational operators are very important in programming, especially when used in the IF 
— statement, discussed on page 3-9. 
| + An expression can be a constant {like 7.2), a variable {like B}, or an arithmetic expression (ike 7.2«SOR6}. 


ory fay pean 
- } # corresponds to a shifted _3; < corresponds to a shifted a P and > corresponds to a shifted { ees), 
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~~ >> LOGICAL EVALUATION > —-> <-> oo 


(Continued) 


LOGICAL OPERATORS —_——————— 


The logical operators are as follows: 


AND 
OR 
NOT 


@ AND compares two expressions. If both expressions are true, the result is true. !f 
one or both of the expressions are false, the result is false. 


@ OR compares two expressions. If one or both of the expressions is true, the result 
is true. If neither expression is true, the result is false. 


@ NOT changes the logical value of an expression. If the expression is true, NOT 
changes it to false. 1f the expression is false, NOT changes it to true. 


As stated earlier, if the result is true, a 1 is returned; if the result is false, a 9 is returned. 


The expressions that the logical operators compare can be either relational or 
non-relational: 
e tf the expression is relational (like A<B), tts true or false designation is 
determined by the particular relational value. 
e@ tf the expression is non-relational {like A), it is true if its arithmetic value is not 
equal to zero; it is false if its arithmetic value equals zero. 


s: first let’s assign values to the variables A, B, C, and D. Execute: 


MOQ Ca 
@Oe) (2 
QOQ Cae 
OOQ C4 


Now execute these logical expressions: 
A<B AND C=D 


Since both relational expressions, A<B and C=D, are true, the result is true and a 1 Is 
displayed. 


Here are some example 


A AND C=D 


The expression, A, is false since its arithmetic value equals zero. The expression, C=D, is 
true. But since AND requires that both expressions be true to return a true result, the 


result is false and a is displayed. 


AOR B 


The arithmetic value of A is zero (false} while the arithmetic value of B is two (true). 
Since at least one of the expressions is true, a 1 is displayed. 





s 
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: . A OR C—D 


Both arithmetic expressions have a value of @ (false). So a @ is displayed. 
NOT A 
Since A is false, NOT A is true and a 1 is displayed. 


NOT BOR NOT C 


Since the arithmetic values of B and C are both non-zero, they are both true. Therefore, 
NOT B and NOT C are both false; so a @ ts displayed. 


~~~ TOTAL MATHEMATICAL HIERARCHY —<-°o—~—o 


TOTAL 


The hierarchy presented below includes the relational and logical operators discussed in 
the previous section. 


z 

> 
2% 
<é 
=< 
we 
a 
as 
= 





Functions highest precedence 
t 
NOT 
" vane 
| + = 
| ) ; Relational Operators 
AND 
OR lowest precedence 


As mentioned before, for operations at the same level in the hierarchy, the order of 
execution is from left to right. 


All operations enclosed within parentheses are performed first, thus altering the normal 
order of execution. 


| 
a! A alee. nee me eee ae eee rane eet =a ee rt ee 
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~~ —~ ADDITIONAL FEATURES <-o7o ow 


In the calculator mode, a few additiona! features are available. 


SIMULTANEOUS CALCULATIONS eee 


It is possible to execute several expressions simultaneously if the expressions are 
separated either by commas or semicolons. 


For instance, if the diameter of a circle is 12 units (d=12), both the area {ad? /4} and the 
circumference (7d) can be solved simultaneously by executing: 





More than two expressions can be solved simultaneously; however, since only 32 of the 
allowable 80 characters can be displayed at once, it may be necessary to hold C=3, the 
left arrow key, down to view all the results. 


The only difference between separating the expressions by commas or semicotons is that 
semicolons generally cause the results to be ‘packed’ together while commas cause the 


results to be ‘spread’ apart. 


PRINT, WRITE gee tS ee ee 


The PRINT statement and the WRITE statement are two important program statements.* 
But they can also be used in the calculator mode, to have the results of calculations 


printed. 


Execute the following example: 
PRINT 22211, 528*8 


The printout will be: 


Goat ot 


An advantage to using the WRITE statement is that you can select the device you want 
to output on. The primary printer has select code 15 assigned to it. But if you have a 
secondary printer, it would have another select code, say, 8. Then either printer could be 


specified in the WRITE statment as follows: 
WRITE (15,*) 22211, 528*8 
or 
WRITE (8,*) 222*11, 528*8 


+ See page 3-4 and 3-21. 
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: Chapter 3 
PROGRAMMING & PROGRAMMING STATEMENTS 


The programming fanguage, BASIC, is used in the Madel 30. In this chapter, the BASIC 
statements are individually discussed. 


The following information is for the experienced BASIC user: 





LPN RE I! ANT TTR I YETI RR SA rt hl ATE I A SY Ot REI RRR See VERT 8K Arpt nL aaa | 


' @ These statements can be used in the same way to which you are accustomed: 


. LET REM DEF FN IF 
PRINT STOP DIM FOR .. NEXT i 
INPUT END COM READ ..DATA j 
COTO GOSUB .. RETURN | 


In some cases, these statements have additional features and minor variations from 
other BASIC languages. But, essentially, they can be used just as you would 
expect. 


_@ These statements, available on the Model 30, are not common to many BASIC 
languages: 


“implied’LET WAIT STANDARD GOTO & GOSUB with OF 


DISP RAD FIXED N Multiple-Line Functions 
WRITE DEG FLOAT N Programmable Tape Commands 
FORMAT GRAD 
e@ These statements have additional features, not common in many BASIC 
languages: : 
i 
STOP DIM READ .. DATA with RESTORE 
END COM 
Nese gaelic ahaa tate gyn ans lS aches tesa) Ae Goa ree eats ho a ed oe ct eee aaa 


Before discussing each statement, a quick introduction to writing and running a program 
will be presented. 


~>~——~--~-—— PROGRAM WRITING <-<-o o> 


A program is a set of instructions organized to accomplish certain tasks. It is organized 
by lines (statements) with each statement preceded by a unique line number. 


Line numbers must appear in the program in ascending order for ‘bookkeeping’ purposes. 
However, in the Model 30, you can type program lines in any order because lines are 
automatically sorted as they are entered. Line numbers 1 through 9999 are allowed. 


Program lines can be a maximum of 80 characters in length. In general, any spacing 
between characters that you use is totally arbitrary. For the calculator inserts appropriate 
spacing into each line that is entered into memory to make the line easily readable upon 
review. Only in quote fields and REM statements (discussed later), will the spacing 
necessarily remain exactly as it was input. 
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~~ +++ PROGRAM WRITING ——*—*—> > 


{continued} 


After each line is written, it is entered into calculator memory when the END OF LINE 
key is pressed. 


Normal program execution proceeds from the lowest-numbered line to the 
highest-numbered line. However, the order of execution can be altered by some of the 


statements discussed later. 


Flowcharting techniques are often valuable aids to program writing. They are discussed at 
the end of this chapter where an example program is flowcharted. 


~~~ PROGRAM EXECUTION —<-—o? ooo 


If a program has been correctly keyed in and is the fowest-numbered program in 
memory, it can be executed by pressing: 


al! 


If the program is operating properly, it will perform the required tasks and then halt. 
However, you can halt a program that is running if you press: 


However, if the program is waiting at an INPUT statement (discussed on page 3-8), press 
— STOP EXECUTE -— instead. 


2 
=o 
q= 
cs 
95 
ou 
rx 

aw 





} ; 
In Chapter 4, all the programming related commands are discussed. 


: The rest of this chapter discusses each BASIC statement. 


At the end of this chapter, the syntax requirements of all the BASIC statements are 
presented. These syntaxes are intended primarily for the advanced programmer. 
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~—_<@-—_~>-—»—@e—~e ASSIGNMENT -3.ocooc coo 





In many BASIC languages, this statement is called the LET statement. But in the Model 
30, the mnemonic, LET, is optional; so it is referred to simply as an assignment or 
‘implied’ LET statement. 


This statement can assign a value to both simple and array variables.+ The value assigned 
can be another variable, a constant, or an expression. 


An equals sign must be used to separate the variable (to the left of the equals sign) from 
its assigned value (to the right of the equals sign). 


Examples 
28 T=2 
2h eget re 
45 Reysi-u 
So SEAL 
BS wie d=: 
fo AEG re 
/ mao oy OT of? - 
md | Ra ee | yaw = 
z= 
, S 
. : : . 7 
3 Lines 15 & 25: The simple variables, G and T, are assigned constant values. < 


Line 35: The expression, G*Tt2, determines the value of D. The variables, G and T, 
must have assigned values for the statement to be executed. 


Line 45: In one statement several variables can be assigned the same value. This ts a 
useful technique for initializing variables in the beginning of a program. 


Line 55: The variable, X, is set equal to its old value plus 1. This type of statement can 
function as a ‘counter’ in a program to determine how many times certain operations are 


performed. 


Line 65: The array variable, U(2), is assigned the value of 1. Since the array variable is 
less than U(11), it need not be dimensioned (see page 3-36 for dimensioning rules). 


Lines 75 & 85: The variable, A, is assigned the value of the variable, G. Both statements 
are equivalent. The word, LET, is optional and can be used in any of the statements 


discussed. 





parentheses are used, as in A(3). However, these parentheses are converted to brackets as in A[3] when the line is 


i 

f 

+ If an array variable is used, it must be properly dimensioned; see page 3-36. When array variables are input, 
entered into memory. 

k 


Ne 
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~~ ~~~» oe PRINT 2.2. o 7c 7. <2. 2 


The PRINT statement can cause various outputs on the printer: 
@ Text can be printed in any form you want. 
@ The values of variables, expressions, and constants can be printed. 
e Printer lines can be skipped to separate outputs. 


Any text that is to be printed must be enclosed by quotation marks; e.g., “ABCDE”. The 
information within the quotation marks is often referred to as a quote field. 


Several variables, expressions, and constants can be included in the same PRINT 
statement as long as they are separated by commas or semicolons. The difference 
between commas and semicolons is shown in the examples. 


Text can also appear in a PRINT statement with variables, expressions, and constants. 
Aside from the quotation marks, no additional punctuation is necessary when separating 
text from other information. If neither the comma nor the semicolon is used, the 


semicolon is assumed. 








Examples 


a 


me 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 


at enc) i et le a es 


oly C0 fe ed Pk ee ee 





Lines 13 & 15: Variables must have assigned values before being used in a PRINT 
statement. 


Line 17: The quote field is printed exactly as seen. Spaces are not ignored in quote 
fields as they are in other places. The semicolon between the quote field and the variable, 
X, is not needed since a semicolon would have been assumed anyway. The variable, X, 
must have an assigned value or an error occurs when the program is run. With X=3 when 
the program is run, the printout is: 


2 
os i -! 


“foT5 EGRAL ef ee 


Line 27: This statement tells the printer to skip a line before doing any more printouts. 
Additional printouts can then begin on the following fine. 


Lines 37 & 47: A variable, a quote field, and an expression are all designated in each of 
these PRINT statements. Ending the first of two PRINT statements with a semicolon {as 
in tine 37) causes both printouts to appear on the same line. Here is the printout: 


_ 
r. 
La 





; 
x 
F 
i 
Ha 
}: 
$. 
% 
= 


1 


vay UNbbe dae 
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A comma could be used instead of the semicolon. But then the printout would be: 


oie Kalk 





air tt 


ny 


Lines 57 & 67: Both constants and variables are printed. The only difference between 
the two statements is that in line 57 the different items are separated by commas, 
whereas in line 67 they are separated by semicolons. Here are the two printouts: 


When only commas are used {as in line 57), successive printout fields are 15 character 
spaces apart and as many as five values can always be printed on the same line. 


However, when semicolons are used, as tn line 67, the vaiues are ‘packed’ together in the 
printout. As many as 12 values can be output on the same line (with a field width of 6 
character spaces per value) if semicolons are used. But if any value requires more than 4 
character spaces (remember, one space is always allocated to the sign), the number of 
available fields per line is reduced. 


Line 77: A long line of text is combined with variables and an expression. The printout 
is: 


ba 


THE SURRE ROOT UF & SQUARED FLUs 4 SBUARED EQUALS 


The maximum printout per line using the PRINT statement is 72 characters. 


Each value output by a PRINT statement is left justified within its respective field (with 
the left-most character space reserved for the sign). 


The same rules that apply to outputs of keyboard calculations if the standard format is 
used (see page 2-1) also apply to outputs from the PRINT statement. ? 


if your printer has a lower-case character set: 


Lower-case characters can be output as text within a quote field if they 
are keyed in with the SHIFT key held down. Text in WRITE and 
FORMAT statements (discussed beginning on page 3-21) performs in the 
same way. 


The PRINT statement can only access the printer with select code 15. Be certain that 
your primary printer is set at this select code. (Most printers are shipped to the customer 
with select code 15 set.) 


be 
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~~ <0 0-0 DISP >< 


The DISP (Display) statement operates like a PRINT statement except that the outputs 
appear on the display rather than on the printer. 


Three advantages of using the DISP statement are: 


@ !f you don’t have a printer, you can still! run programs. 

@ In many programming applications, various operations are performed over and 
over: in these cases, the DISP statement is a good tool for viewing tne changing 
values of variables — without having to use printer paper and by taking less time 
than it takes to print the information. 

@ It’s extremely useful in labeling INPUT statements (see page 3-8). 


Two advantages of using the PRINT statement are: 


@ Permanent records of the outputs can be obtained. 

e For output lines greater than 32 characters in length, not all the information can 
appear on the display at the same time, whereas the same information can appear 
on one printed line. (The DISP statement could still be used, however, if the 
program ends with the display still visible; then —<_, the feft arrow key, could be 


held down to view the end of the display.) 











Examples 


i Se oe 
> 
mt Tt 





tol bl a a 


i oe Ae 


Pa a 


Lines 29, 39, & 49: These statements merely show that the same operations that are 
allowed in a PRINT statement are also allowed in a DISP statement. The spacing between 
fields would be the same with either PRINT or DISP. Here are the three displays: 

















NOTE 
These lines are not meant to be run as one program. If they were, lines 29 
and 39 would appear on the display for just an instant. If, in a program, 
you wish to have two or more successive displays, the WAIT statement 
(see page 3-17) can be used to prolong each display. 





es 


{f the last visible output in a program results from a DISP statement, the display remains 
even after the program is completed. 








wee gee 


1, 
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>>>. > ~~~ STOP, END <2. _2.__2 eo 


Either the STOP or END statement can be used to terminate program execution. The 
statements can be located in any portion of the program. 


The only difference between the two statements is as follows: 


@ When STOP is encountered, the program halts and the current position of the 


program line counter* is retained. 
@ When END is encountered, the program halts and the program line counter reverts 
to the lowest-numbered statement in memory. 


The CONT (Continue) key is discussed on page 4-4. When the keys — CONT EXECUTE 
— are pressed, the calculator will begin execution at the position of the program tine 
counter. So if a STOP statement is encountered, the program halts. The vatues of 
variables can be checked. Then the program can be continued, as though it had never 
been halted, by pressing: CONT EXECUTE. 


Examples 


Lines 10 through 50: If this program is run, lines 10 through 30 are executed; the 
program halts after the STOP statement with the program line counter positioned at line 
40. If the keys — CONT EXECUTE — are then pressed, lines 40 and 50 are executed. 
The program halts after the END statement with the program line counter repositioned at 


line 10. 


If line 30, in the previous example, had been an END statement, line 40 still could have 
been accessed by pressing: 


Recomm 


=O0|} 


But to have the program halt during, say, a FOR...NEXT loop {see page 3-12) and 
then to be able to continue as though it had never been halted, the STOP statement must 


be used. 


The two keys, (sr | and eG cannot be used as program statements. 


+ The ‘program line counter’ is an internal device used by the calculator to determine the order of program execution. 
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~~» ~~~ INPUT —.°. °c co 7° oo 


The INPUT statement allows variables to be assigned values from the keyboard during 
program execution. 


When the INPUT statement is accessed, a ‘?’ appears on the display. A value can then be 


input for each of the variables designated in the INPUT statement. For instance, in the 
statement: 


18 IHPUT AsBsCes Dod 
One value must be assigned to each of the four variables. 


Values can be assigned individually or in groups. For instance, the values, 1, 2, 3, and 4, 


can be assigned as: 
+ 
al) al) al) off 


O08080e(|) 


In the first case, the ‘?’ will reappear on the display after each input until all four values 
are input. 


OF as: 


In the second case, all four values are input together. The values can be separated either 
by commas or by semicolons. 


In both cases the values, 1, 2, 3, and 4, are assigned to A, B, C2, and D(3), respectively. 





Examples 
2 THPUT Te fiis Be ao DDSF "R EGUALS"S 
22 THPUT IC iI; B02] 42 IHPUT F 


Line 12: The simple variables, D, D1, and D2, are to be assigned values. When more 
than one variable is designated in an INPUT statement, the variables must be separated 


by commas. 


Line 22: The array variables, D(1) and D(2), are to be assigned values. Since the array 
variables are less than D(11), they need not be dimensioned (see dimensioning rules on 


page 3-36). 


Lines 32 & 42: By ending line 32 with a semicolon, the text, R EQUALS, will be 
displayed together with the next display in the program, which is the ‘?’ from line 42. So 
the display will be: 





+ Either the EXECUTE or the END OF LINE key can be pressed to assign values to variables in the INPUT statement. 








Then the variable, R, in line 42 can be assigned a value. 





When a program encounters an INPUT statement, a *?’ appears on the display and the 
program waits for values to be keyed in. If you prefer to terminate the program at this 
point, press the keys: STOP EXECUTE. 


~~ <<< <2 ———-~——@e |F -—. 2. 2. 2. 7 7° 2. — 


The IF statement contains an expression and another line number. First, the expression is 
logically evaluated. If it is evaluated as ‘true’, the program continues execution at the 
specified line number. But if the expression is evaluated as ‘false’, the program continues 
execution in its normal sequence with the statement following IF. (Logical evaluation is 
discussed in Chapter 2, beginning on page 2-19.) 


Examples 
1 PHP 3 
g2 IF =3 THEN i42 da4 IF “ AMD ¥ THEN 424 
ap IF INTé#3=3 THEN 222 did STOP 
42 STO 424 FPRIWHG Sai 
: 434 IF H+ <= 18 THEH 464 
: 444 DISP ¥-3 
S13 IF Y<Nt2? THEN 333 dad STU 
322 IF ¥ THEN 363 Hoe ee Aen 
232 STOR 474 STF 
; y 


Line 1: For all of these examples, let’s assume that X=3.01 and Y=23. 


Lines 22 through 42: The IF statement in line 22 is evaluated as ‘false’ since 3.01 is not 
equal to 3. So the following statement, tine 32, is accessed. This IF statement is then 
evaluated. Since the integer value of 3.01 equals 3, the statement is evaluated as ‘true’. 
So the program continues execution at line 222. 


Lines 313 through 333: Since Y is greater than X?, the IF statement in fine 313 Is 
evaluated as ‘false’. So instead of accessing line 333, the program continues execution in 
its normal sequence with line 323. Line 323 is logically evaluated as ‘true’ since Y has a 
non-zero value. So the program continues execution at line 363. 


Lines 404 through 474: Since both X and Y have non-zero values, line 404 is evaluated 
as ‘true’ and program execution is transferred to line 424 where the values for X and Y 
are printed. Line 434 checks to see if X+Y is less than or equal to 10. The evaluation is 
‘false’ so program execution continues at line 444. The value of Y—X is computed and 


displayed. Then the program stops at line 454. 





Avoid unnecessary punctuation; for instance: 
22 IF #4=2,s THEN i42 


The comma is not allowed here. If it’s inadvertently keyed in, ERROR 24 occurs. 


"NERO pret rn = et ete tee tn ae Re RR I RR IR A OE CY DTT ee rey g ORE SE ST nee oe MRR kao emeree corer cnet tte a et ee eer ary 
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GOTO 





The GOTO statement is used to alter the normal! sequence of program execution. The 
program continues execution at the line number specified in the GOTO statement. 





Examples 
#1 #2 
ii Ai igs £=8 
el if Ate. 1eée THEM Ss! tli x=1 
31 DISP Asatte 1i5 25atc 
42 S70F ize JISP Atte 
wi HAH+1 125 4=at! 
Bi GOTO si 13H GOTO iis 


Example No. 1: This program ‘loops’ (repeats part of itself) several times until the {F 
statement, line 21, is no longer true; that is, until AT221000. If At2<1000, the variabie, 
A, is incremented by 1 in tine 51. Then the GOTO statement, line 61, is executed 


causing the program to loop back to line 21. 


Example No. 2: The GOTO statement in this program causes the program to loop 
between lines 115 and 130. This is a ‘closed loop’; that ts, there is no program statement 
in the loop that can cause the loop to be exited. So to halt this program, press the STOP 


key. 





Line numbers in GOTO statements must be constants; statements like, 15 GOTO P, are 
not allowed. Furthermore, the line number specified must be in memory when the 
program is run or else an error will occur. 
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The REM (Remark) statement is merely a note to the programmer and is not executed 
by the program. However, the statement does appear on a program listing. 


Any series of characters can follow REM, the only restriction being the maximum line 
length of 80 characters. 


Examples 


0208 LS al 





AT FA 


Tat Balk fs tas 


en Oe 
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~~ —~<@—~@—~@—~@e FOR ... NEXT « «oc oc co oo 


The FOR and NEXT statements allow for the controlled repetition of a group of 
statements within a program. 


The FOR and NEXT statements form a loop with the statements between them in a 
program. The FOR statement defines the number of times the loop is to be performed. 


For example: 


TO 3 


j==1 
Cnad 
weds 
"Th 
7 
il 
Im 
i 
font 


pee ; 
Tye # a ket TT 8 8 eI 
oe ia 


rm! 
m 
vee 
Lom 


Pd 


This FOR... NEXT loop would be executed five times: when !=1, 2, 3, 4, and 5. Each 
time the NEXT statement is executed, the value of | is incremented by one. If 1 is less 
than or equal to 5, the loop is executed again. But when the value of | passes the final 
value, that is, when I=6, the statement following the NEXT statement (in this case, line 


110) is accessed. 


The advantages of using FOR...NEXT rather than IF can be shown in the following 
simple example where the numbers 1 through 100 are to be displayed in succession: 


Using IF Using FOR... NEXT 
1a N=] lf FOR H=1 Tu igs 
2H TF WH>isa THEN 68 Za DIS bh 
2a DISP # Se HEST N 
46 H=H+i 48 ENT 
Ba GOTO 2a 
BA EMD 


In the example the program is easier to key in, takes up considerably less calculator 
memory, and executes faster if the FOR. . .NEXT loop is used. 








Examples 
#1 #3 
ii f=6 i3 ic 
Zi FOR F=38 70 ish 24 
21 f=2evF ao 
41 HEST P 49 
Si PRINT “THE TOTAL Js ao 
Bi EHD HA 
#2 a? 
1 #=8 14 
1i IHPUT Mat oar F 
eioFOR Fan Ta & ao 
Si F=Pte qa 
44 HEHT F of Te°F t 
Si Ppl: “TRE: Laren tae aie, aes 
B61 ENT S74! 








|" y 6-7 AERROPROT patna spstemains to Cro 
a sos 


I LL A ee 


“om, 


cs peteabinted 


ee 


Example No. 1: The initial value of the variable assigned in the FOR...NEXT loop 
need not be 1; in this case, P is assigned the value, 90. This example takes the summation 
of the integers, 90 through 100, and prints the total. 


Example No. 2: This example is like example no. 1, except that the user can vary the 
numbers to be totaled. The variable, P, in line 21 is assigned the variable value, M, for its 
first value and is assigned the variable value, N, for its final value. M and N are both 
assigned values in the INPUT statement, line 11. 


@ If M=3 and N=5, the summation of 3, 4, and 5 would be taken. 
@ If M=3.1, and N=5.1, the summation of 3.1, 4.1, and 5.1 would be taken. 
@ If M=3.1 and N=5, the summation of 3.1 and 4.1 would be taken. 


In each case the value of P increments by 1 after each loop. In the last case, the loop 
would be performed only twice, when P=3.1 and 4.1; for when P increments to 5.1, the 
value of N, which is 5, is exceeded and line 51, which follows the NEXT statement, is 
accessed. 


By the way, if M is set equal to a value greater than N, the loop is immediately bypassed 
and the total printed in line 51 would be @. 


Example No. 3: An aspect of the FOR...NEXT loop that is often overlooked is 
emphasized in this example. After each loop is performed, the NEXT statement, line 39, 
increments the value of A by 1. It then compares the incremented value to the final 
value indicated in line 19. If this incremented value is less than or equal to the final 
value, another loop is performed starting at line 29; but if the incremented value is 
greater than the final value, (that is when A=13) the loop is no longer accessed and line 
49 is executed. In this tine the value of A is printed. Although the final loop is 
performed when A=12, the last incremented value for A is 13 and the calculator memory 
retains this as the value of A. So the total printout would be: 


ht 
he 
fia] 
e 
ad 
Po 
t 


Pal = 4 a 6 ¢ 3 


12 


In all cases, the final value retained for the variable in the FOR ... NEXT loop is greater 
than the final value in the FOR statement. In some programs, this could be a minor 
problem. The next example shows how to compensate for it. 


Example No. 4: This program calculates the average of the inputs (either version of tine 
number 59 could be used). 

@ in the first case, the summation {Z) is divided by the number of inputs (A—1). 
A-—1 is used to compensate for the final incremented value of A, as discussed in 
the previous example. 

@ in the second case, Z is divided by V to get the average. Since V retains its initia! 
value, no compensation factor is needed. 


(continued) 
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~>—~+>—@—~@—@—~@ FOR ... NEXT ~< «7c 7.7. -> 





{continued} 
Se “i 
#5 > 
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Example No. 5: This program shows that a FOR...NEXT loop can be exited before 
the final variable value is reached. When this program halts, the printout is: 


BRE a 
3 tee? tee 


at 


at 


Example No. 6: This program shows how the FOR ...NEXT loop can be used to assign 
values to arrays. In this example, the array variables, A(1) through A(4) are assigned 
values. The printout is: 


1 + 
ad 


my CT 


ye + 
pee fuk 


FOR...NEXT loops can be nested; that is, they can be located inside one another. 
However, one loop cannot overlap another. For instance: 





Correct Incorrect 
2 O15 ro is 
ZH ne oe Lote 
HE HEE T = mie a 
98 Heel & Sh he 





Notes: 


@ Entering a FOR...NEXT loop at any place other than the FOR statement (with 
statements like GOTO or IF}, can cause unpredictable results and should, 


therefore, be avoided. 
@ Each FOR statement can have only one associated NEXT statement. 


An additional feature of the FOR and NEXT statements is discussed next. 
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2 >> <——~<- FOR ... NEXT with STEP <---<- 
It's not necessary that the variable in the FOR ... NEXT loop be incremented by 1 each 
time the loop ts executed. For instance: 
By adding STEP to the FOR statement, the variable will be incremented by the number 
following STEP (in this case, 3). So this loop will be executed five times: when 1=@, 3, 
6, 9, and 12. But if the program read: 
MW oMES TL 
The loop would be executed only four times: when |=, 3, 6, and 9. As soon as the 
incremented value passes the final value, the loop is exited. a 
Examples F 
) #1 
fi oo as =? TE: ef 
Or }- ae hee 
i =i TH 4 STEF 


Example No. 1: Either version of line 12 could be used with identical results. In either 
case, when the program loops, the value of X is incremented by 1. Therefore, if you 
want the variable to increment by 1, it is unnecessary to use the STEP feature. 





th 

#2 

S80 Teams nod ea aa Pea oo a = 
£eP Po he ok is pa or i ee = 
pas Ge S pence 

woot 8 ry i.& 

i. a ee ie i 

EELS _ 

am Det: 

So RL 


Example No. 2: This loop is executed three times: when C=1, 3, and 5. The final 


display is: 
\J 





(continued) 
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{continued} : ! 
#3 ; 7 





Rpe eT. 
i ed 


Eta di 


A MO ROC Oo | 


Example No. 3: This program shows that FOR...NEXT loops can be incremented by 
negative values, in this case, —4. This loop is executed four times: when T=4, 0, —4, and 


—8. The printout is: 


To 
ai if 
re es 
an et 
= us 
-4 Le 
rary ey] 
-2 G4 


ch =. 
1 av be AG 
; mot —. “ny 7“, “_s% Si vl pual ae i 
: i¢4 FOR S=-he TU -38 sIlkr -is 
a fate Pip fT py 
me PRiril SIMtS 3 : 
7 A L map — “ 
B4 Hoar = 
44 FHT ( 
? Oa Bir oo, } 


Example No. 4: Line 4 allows angles to be calculated in degrees. The FOR...NEXT 
loop is incremented negatively as it was in example No. 3. The loop is incremented five 
times: when S=—30, —45, —60, —75, and —90. The printout is: 





—H. Ye 
-H, 3 
-8.5 
-1 


The step size need not be an integer value; e.g., STEP 2.5 is allowed. 


Furthermore, the initial variable value, the final variable vatue, and the step size can all 
be expressions; e.g., 


fo ™ 





nit alt, 
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j > —- <—<-<-<-— WAIT . <2. 72. <- 7- << 


The WAIT statement introduces a timed delay between two program statements. It’s 
particularly useful for delaying consecutive printouts or prolonging displays. 


The WAIT statement causes the program to pause the specified number of milliseconds 
(1000 milliseconds = 1 second). The delay can be set to vary between approximately @ 
and 33 seconds. 





Examples 
ak Ah 
+1 #2 
iG ¥=0 is LOH T TOUCH HE 
rs , fry TF Sere bare et 
gon : fers a RT 
a 5 si Be GLH 
ari Ai: di 4088 
sa =e Si an 
Ei To Pa 


Example No. 1: In this program, the value of Y ts incremented by 1; and for each value 
of Y, 2” is calculated and displayed. By putting in the statement, WAIT 3000, about a 
three second delay occurs between consecutive displays. 


the quote field in line 30 is displayed for about 4 seconds, etc. The WAIT statement has 
one additional feature. Most of the Model 30 keys, if pressed, will cause the current 
WAIT statement to be terminated and program execution to be resumed. (Of course, if 
the STOP key is pressed, the program halts.) So if the calculator is displaying: 





) Example No. 2: The quote field in line 10 is displayed for about 32 seconds, and then 





The maximum delay that can be specified in a WAIT statement is about 33 seconds. Any 
WAIT statement with a number greater than 32767 will wait the maximum amount of 
time. 


The specified delay in a WAIT statement can be a constant, a variable, or an expression. 
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READ 


DATA 





~~ _~@— READ ..». DATA ~<-—o-o—_2.__2o_2>- 


The READ and DATA statements combine to assign values to variables. The READ 
statement determines the variable (for instance, 10 READ Y}, while the DATA statement 
determines the value to be assigned to the variable (for instance, 90 DATA 12.4). 


More than one variable can be specified in a READ statement (for instance, 10 READ 
X,Y,Z) and several values can be specified in a DATA statement (for instance, 90 DATA 


§.1, 7.6, 9.3, 4, 16, 9.2). 


The calculator uses an internal mechanism, called a ‘pointer’, to locate the data element 
that is to be read. The leftmost element of the lowest-numbered DATA statement is read 
first. After this element is read, the data pointer repositions itself one element to the 
right, and continues to do so each time another data element is read. 


After the last element in a DATA statement is read, the data pointer locates the next 
higher-numbered DATA statement and repositions itself at the first element in that 
statement. But if there are no higher-numbered DATA statements, the data pointer 
remains at the end of the previous DATA statement; and any effort to read additional 
data will result in an error message. 


The location of the DATA statement in a program is immateria! unless there is more than 
one DATA statement; if so, just be sure they are in the order you want. 


Examples 


Jenssde 





LAE fa a Put 


Pali beat: 





ho Msg Pe Ped Pu ba 





Wy TP ta fae 





Example No. 1: This example shows that several READ statements can apply to the 


same DATA statement. The data pointer just movesto the right each time another data 
element is read. The first variable is assigned the first data value, the second variable is 
assigned the second value, and so on. 





ca * 


BY 


bac bat germane, - 


3-19 


) Data tan appear in more than one DATA statement. Thus, the following representations 
would al! be equivalent: 





Example No. 2: READ statements are often used in FOR...NEXT loops. Each time 
this loop is executed, a new value for X is read and a new line is printed. The printout 


be a ey 





Ca a 


) Example No. 3: The DATA statement can appear anywhere in the program. In this case, 
al it is the first statement. in this program, the FOR... NEXT loop is executed four times, 
and each time, new values are assigned to X and Y. The printout is: 


ay 


Ate tt 
fu. 


IA sj 


Pi: fete 


we 


bet Fy jee 


~* 

Teed 
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Example No. 4: In this program one READ statement is outside the FOR...NEXT 
loop (thus being executed only once) and one is inside the loop (thus being executed 
three times}. The printout is: 





The DATA statement is accessed only by a READ statement; otherwise, the program 
ignores it. 


Once the READ statement variables are assigned values from a DATA statement, the 
statement following READ is executed. 
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~>—>—> READ ... DATA with RESTORE <-> 


Data elements can be read more than once if the RESTORE statement is used. 


There are two variations of the RESTORE statement; for instance: 


Hu RESTORE or $4 RESTORE 126 


@ if the first RESTORE statement, 80, is encountered during program execution, 
the data pointer reverts to the first data element in the lowest-numbered DATA 


statement. 


@ If the second RESTORE statement, 90, is encountered during program execution, 
the data pointer reverts to the first data element in the DATA statement specified 


{in this case, line 150). 


Examples 
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Example No. 1: [n this program, immediately before the RESTORE statement is 
accessed, the data pointer is located after the last data element in line 110. The 
RESTORE statement resets the data pointer to the first element in line 110 so that the 


data can be reread. 


Example No. 2: {!n this program, there are two DATA statements (line 120 and line 
130). Immediately before the RESTORE statement is accessed, the data pointer is 
located after the last data element in line 130. This RESTORE statement directs the data 
pointer to the first element in line 130. If the line number, 130, had not been specified, 
the data pointer would have been reset to line 120. 


In both examples, the printout is: 
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>.>... -—-—e WRITE 2 7c. _7- +. 


This section shows how the WRITE statement can be used like a PRINT statement 
although it is generally used with the FORMAT statement (discussed on page 3-22). 


When used without the FORMAT statement, the WRITE statement works like a PRINT 
statement with one major exception: the desired output device can be specified in a 
WRITE statement whereas the PRINT statement always assumes the primary printer 
{select code 15). 


The WRITE statement specifies the output device by select code. The primary printer is 
always select code 15. If you have a secondary printer, it might be set at select code 8. 
Either of these select codes (or the select code of another Goan Output device) 
could then be specified. 


To write the constants, 1, 2, 3, on the primary printer, the statement could be: 


ay? 


Within the parentheses, the select code* is specified, followed by the ‘*’. The ‘* 
indicates that the WRITE statement is being used without a corresponding FORMAT 
statement and that all the rules of the PRINT statement are to be followed when 
outputting the constants, expressions, etc. 


Examples 
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Example No. 1: If a secondary printer with select code 8 is connected to the calculator, 
the printout would be: 


“Py iSee hp = 


cry 


Example No. 2: In this program, if both the primary printer (select code 15) and the 
secondary printer (select code 8) are connected to the calculator, either one can be 
accessed. The value input for the variable, S, determines the select code. So if 15 is input 
for S and 6 is input for Z, the printout on the primary printer would be: 


] 
rr 
‘ 1 
1 
ty 


J 
aa 
tr 

t 


+ The select code can be a variable. 
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FORMAT 


le a a age FORMAT ~«.—°.oe-_+2.__2-_o— 


The FORMAT statement gives output specifications to the WRITE statement that 
references it. The formatting of numbers and the spacing between successive items is 
easily controlled with the FORMAT and WRITE statements. Also, symbols not available 
with the PRINT statement can be output by using FORMAT and WRITE. 


The WRITE statement references a FORMAT statement as follows: 


Payee i ae 


Mee. i eae ert 


where, in this example, 15 refers to the select code of the output device, and 200 refers 
to the line number of the corresponding FORMAT statement. 


Like the PRINT statement, the WRITE statement can output: 


@ Text (in a quote field) 
@ Values for variables 

@ Values for expressions 
@ Constants. 


Text is output the same in either statement; the information inside the quotation marks 
is output character for character. 


if expressions, variables, and constants are specified in a WRITE statement, their values 
can be output according to either of the following FORMAT statement specifications: 


® Fw.d where F indicates fixed-point format; 
w indicates tota! field width (in character spaces); 
d indicates the number of digits to the right of the decimal 
point. 


e Ew.d where E indicates exponential format (often called floating-point or 
scientific notation); 


w indicates total field width (in character spaces); 
d indicates the number of digits to the right of the decimal 
point. 


The other available FORMAT statement specifications are: 


ex which indicates a blank character space; 

e/ which indicates a carriage return—line feed for the printer; 

@ “text’’ which indicates a quote field (also allowed in the WRITE statement); 

®B which allows symbols that are otherwise not obtainable to be output by 
the Model 30. 


Any combination of the specifications can appear in the same FORMAT statement; but 
different items must be separated by commas. 


Any of the specifications can be duplicated a specific number of times if a repeat factor 
is specified; for instance: 
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J | The first fixed-point field would appear twice, followed by four character spaces, and 
then another fixed-point field. 
The FORMAT statement, like the DATA statement, can appear anywhere in the program. 
It is never executed by the program until it is referenced by a WRITE statement. 
Examples 
Lines 12 and 20: The three numbers are output according to the three fixed-point 
formats. The printout is: 
Fo AA Te aaa 22. BAe 
a cn yee eyed 
1 2 3 
Fw.d - The field widths, w, for the three printouts are 6, 10, and 2, respectively. in the 
printout, the three field widths have been labeled 1, 2, and 3. In the first two formats, 
the number of digits to the right of the decimal point is 1 and 2, respectively. In the 
) third case, since d=@, the decimal point is suppressed. 


Notice all three printouts are right justified within their respective fields. In each case, 
there is a space available for the sign (although in 1 and 3, since the sign is ‘+’, the sign ts 
suppressed). Also, in every case (except for d=@), the decimal point takes up one 
character space. If the field width does not allow for both the sign and the decimal 
point, the value will not be output (see lines 90 and 99 on the following page). 


Lines 33 and 40: The two numbers are output according to the two exponential 
formats. The printout is: 


Ew.d The field widths, w, for the two printouts are 8 and 12, respectively. The number 
of digits immediately to the right of the decimal point, d, is 1 and 2, respectively. 


The ‘E’ format follows the same general rules as the 'F’ format: printouts are right 
justified; the sign (or assumed sign} and the decimal point take up one character space 
each. But in ‘E’ format, the field width must be at least four greater than in ‘F’ format 
because the last four digits are needed to indicate the power of 10 to which the number 


should be raised. 


) (continued} 


+ In these examples the ’! will be used to indicate a blank space in the printout. 
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(continued) 
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AAS. 88 aa5, FRESH 
AA, BE AAS, SHE + etl 
DAS, BE 


After the first two values are printed according to the specified formats, the printer 
performs a carriage return—line feed (resets itself to the beginning of the next line). Then 
two more values are printed according to the same two specified formats, etc. 


Lines 90 and 99: The WRITE statement is located before the FORMAT statement; it 
makes no difference to the calculator. For a value of 12.2 to be printed as it appears 
would require an ‘F’ format with field width of 5 (to allow for the implied sign). Since 
the specified field width of 4 is not large enough, the calculator outputs dollar signs, 
SSSS, in the entire field to indicate the lack of space. The second vaiue, 1.8, is rounded 
up to 2 since the second format calls for zero decimal places. (Incidentally, had this 
specified field width been one less, dollar signs would also have been displayed here.} 
This printout is: 


SEFFaAceros 
a | 
1 2 


Formatting Rules: 


@ Using Fw.d If d > @, then the minimum field width allowable is w=d+3. If d=0, 
the minimum field width allowable is w=2. One of the character spaces is always 
allocated for the sign {although only the minus sign is displayed). Another space 
is needed for the digit preceding the decimal point. Additional spaces are required 
if more than one digit precedes the decimal point. For instance, F4.1 is sufficient 
for the number, 2.6; but F5.1 is needed for the number, 12.6. 


@ Using Ew.d If d > @, then the minimum field width allowable is w=d+7. If d=@, 
the minimum allowable field width is w=6. Of course, the field width can be 
greater to increase the number of blank character spaces. 


The following six exampies show additional formatting techniques. 


#1 #3 

18 FORMAT FS. G.2e8s "TROMBOHES ” {@ FORMAT Fo. eses "TROMBONES ” 
12 WRITE 15910376 12 WRITE (15.18976 

i¢ END 14 ENT 

#2 #4 

14 FORMAT FS.a 10 FORMAT FS.a-- 

12 WRITE €15:19976s " TRUMBOHES” 12 WRITE (15.289 765" TROMEGHES” 
14 END id END 
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Example No. 1: The number, 76, is printed according to the F5.0 specifications: it is 
followed by two character spaces (2X) and the word, TROMBONES. The printout is: 


etic “PL SiheaEr ye, io 
1S, Petit 


Example No. 2: The number, 76, is again printed according to the F5.0 specifications. 
The FORMAT statement then checks for additional format specifications. Since nothing 
follows the F5.0, the printer performs a carriage return—line feed. Then the WRITE 
statement is checked for additional specifications. Since there is a quote field following 
the 76, the quote field is output. The printout is: 





Example No. 3: This output is the same as in example no. 2. This time, however, the ‘/’ 
specifies the carriage return—line feed. As mentioned, the printout is: 





Example No. 4: In this case, the printer performs the carriage return—line feed twice: 
first when the ‘/’ is accessed; and then because nothing else follows the ‘/’. The printout 


IS: 


my 


Example No. 5: This example shows that after the value, 76, is output according to the 
F5.0 specifications, the text in the FORMAT statement is output before the text in the 
WRITE statement; and since nothing follows the text in the FORMAT statement, a 
carriage return—iine feed is performed before the text in the WRITE statement is output. 


The printout Is: 





Example No. 6: This example illustrates a technique that often Is useful. Occasionally it 
would be beneficial to suppress the carriage return—line feed before the WRITE 
statement is completed. A ‘dummy’ format specification can be used to accomplish this: 
that is, an ‘F’ or ‘E’ specification in the FORMAT statement without a corresponding 


value in the WRITE statement. The printout is: 


(continued) 
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(continued) 


Three more examples are included here: The first example includes all the concepts 
discussed earlier, and the last two examples show some applications of FORMAT B. 


#7 

16 IHPUT Havs2 

FORMAT "AVERAGE": Sis “MEAN: Ses “AEDS ss PSL Ls bea Po. 
MRITE ¢Loschoas Ved 
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WRITE (15: 209340915 93134 
FORMAT L1Ms "2 9 2"s4sGs "LOOK AT IT'S" abs "ITS": 
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BRISF “WHICH IS CORRECTs 1 OR 2°: 
IHFLUT & 

FRIMT 

IF #=2 THEN 38 

PRIHT #°IS THE IMCORRECT ZESPOHSE” 
STOP 

PRIHT #"IS THE COPRECT RESPONSE” 

4 END 
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Example No. 7: Suppose X, Y, and Z were input as 9.9, 10.2, and 10.3, respectively. 
When the FORMAT statement is accessed, the headers for the three numbers are output 
with a character spacing of five between words. Then the printer performs a carriage 
return—line feed and prints the three numbers according to the specified formats. The 
spacing between the ‘F’ fields (6X and 5X) is needed so that the numbers will be 
positioned under the appropriate headings. (Generally it takes a few attempts before the 
spacing works out correctly.) The printout ts: 


AVERAG 





chi 
eit 
tee 


Example No 8: FORMAT B is used to output symbols not otherwise availabie on the 
Model 30. ‘B’ is indicated in the FORMAT statement and the corresponding number in 
the WRITE statement is interpreted as a code. (This code is actually the decimal 
equivalent of an octal number understood by the calculator.) The symbol you will get for 
each number input is shown in Table F-2, Appendix F. Most of these symbols are already 
easily accessible on the Model 30 without using FORMAT 8B; but a few of them cannot 
be obtained unless FORMAT B is used. For instance, in the first printout: 


ae 


Using FORMAT 38, the printout ts: 








Hore 


kes 
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3 None ‘of these symbols can be output without using FORMAT 8B. Quotation marks (") 
can be input to represent quote fields but cannot be output within quote fields. As can 
be seen by this printout, the codes for these symbols are 34, 91, and 93, respectively. 


Example No. 9: In this example, practical uses for some of these symbols are shown. 
Everything in the FORMAT statement is output as usual. When the first ‘B’ is 
encountered, the first number in the WRITE statement is taken as the code for the 
symbol to be output there. When the second ‘B’ is encountered, the second number is 
the code, etc. 


The printout from the WRITE and FORMAT statements is: 


This grammatical question has two choices, 1 or 2. If ‘2’ is keyed in when the INPUT 
statement is encountered, the final printout is: 


Unlike the PRINT statement, in which the maximum printout per line is 72 characters, 
) with WRITE and FORMAT the maximum printout per line is restricted only by the 
character length of your printer. 


A semicolon or comma at the end of a WRITE statement suppresses the carriage 
return—line feed if the corresponding FORMAT statement specifications have not been 
completed. 
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The TAB command is most often used with the PRINT statement but it can likewise be 
used in DISP and WRITE?* statements. With the TAB command, outputs can be located 
at a specified character position. Character positions @ through 71 can be designated. 
Notice it is the absolute character position that is specified — not the character spacing. 
lf a character position greater than 71 is specified, a carriage return—line feed is output. 


The TAB command can also specify a variable character position. 


Two reminders: 


e {tf TAB is used in a DISP statement, anything past TAB3I wil! not be visible on 
the display. 

@ TAB is ignored if the character position is already past the specified TAB; for 
example, 10 PRINT 12, TAB6, 24. Since the punctuation after the 12 is a comma, 
the value of 12 is automatically contained in a 15 character field. And so, TAB6 
is irrelevent. 


Examples 


TY Sc a ce PAP r=" se mp pyre 





PRINT with TAB 








Example No. 1: The PRINT statement in line 20 sets up the headers for the variables, 
X, Y, and Z. The first heading, AVERAGE, starts at character position @: the heading, 
MEAN, starts at character position 20; and the heading, MEDIAN, starts at character 
position 40. Then in line 30, the variables are printed under the three headings. Suppose 
X, Y, and Z were input as 11.23, 11, and 11.4, respectively. The printout would be: 


Trem Le 
a 


MEDIA 





Example No. 2: In this example, an application of a variable TAB is shown — TAB 
(35+25*SINX). The TAB origin is at character position 35. The curve for the sine of X 
fluctuates to either side of the origin — to the right for positive sine values and to the 
left for negative sine values. (The sine of X is multiplied by a factor of 25 in this ¢ 


+ The WRITE statement will accept the TAB command only when WRITE operates like a PRINT statement; e.g., 10 
WRITE {15,+)2, TAB 30, 4. 
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example to enable the TAB to make larger increments.) This program halts whenever you 
press the STOP key. The printout is: 
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The GOSUB statement transfers program execution to the line number specified by 
GOSUB. Eventually, a RETURN statement is accessed, which transfers program execution 
to the statement following the previous GOSUB statement. 








The GOSUB and RETURN statements eliminate the need to repeat frequently used 
groups of statements in a program. 
Examples 
#1 #2 
Ln oTRPRIY A 1G THRU? fH 
; Se 4 
SH STOP 
9398 STOP 
THE =e : ( 
: izGG RBETUS ; 





10—60 10—60 10-60 
1000—1200 1000 1000—1010 


RE TURN ; 
m ENT ames em 
The order of execution by line number in the two examples is: 
Example =1 Example =2 
70—200 1020—1200 2000—2200 
1000—1200 70—900 1020—1200 


when A*N<150 when A*#N2150 
210—990 70—300 


In both examples, before each subroutine (lines 1000—1200 and lines 2000—2200) there 
is a STOP statement. A statement like this is a good precautionary measure to ensure 
that a subroutine is not inadvertently accessed; if it is, the error — improper RETURN — 
will probably occur. 


Example 2 (when A*N2I50) shows that subroutines can be nested; that is, a second 
subroutine can be executed before the RETURN in the first subroutine is accessed. 


oo 





Each nested subroutine requires one additional word of calculator memory during 
program execution. Therefore, the number of nested subroutines is restricted only by the 
size of the calculator memory. 
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+++ GOTO & GOSUB with OF «++. 


The GOTO and GOSUB statements were discussed earlier (pages 3-10 and 3-30, 
respectively). In both statements the program reverts to the line number specified. But, in 
this section, two additional features of the statements, called the computed GOTO and 
the computed GOSUB, are discussed. 


Both statements contain an expression followed by the word ‘OF’; to complete the 
statement, one or more line numbers are specified. 


The expression is evaluated and its rounded integer value is determined. This integer value 
then acts as a pointer to determine which line number, from those specified, is to be 
accessed. The first line number specified corresponds to an integer value of 1, the second 
line number corresponds to an integer vaiue of 2, etc. ‘ 


If the rounded integer value of the expression is either less than 1 or greater than the 
number of specified statements, then the statement following the computed GOTO or 
GOSUB statement is accessed. The form is always the same as seen in the following 
examples. 


Examples 





Example No. 1: In this example, the expression to be evaluated is merely the variable, 
X. Values of X equal to 1, 2, 3, or 4 correspond to the four line numbers listed. If X=2, 
the second line number {line 330) is accessed. If X=2.5, the value of X is rounded to 3 in 
the computed GOTO statement, and the third line number (line 360) Is accessed. 
(Decimal values of .5 and greater are always rounded to the next higher integer value.) If 
the rounded integer value of X is either less than 1 or greater than 4, the statement 
following the computed GOTO statement (line 30) is accessed. 


Example No. 2: This example uses a computed GOSUB statement. The expression to be 
evafuated is: ABS{X—Y). Since three statements are specified, if the integer value of 
the expression is 1, 2, or 3, the first, second, or third subroutine is accessed; otherwise, 
the following statement, line 30, is accessed. 
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The DEF FN (Define Function) statement can define a function in one line (for 
single-line functions) or in several tines (for multipletine functions). Single-line functions 
will be discussed first. 





SINGLE-LINE FUNCTIONS 


If an algebraic expression has to be evaluated several times in a program, it may be 
convenient to define the expression as a function. 


A maximum of 26 defined functions, FNA through FNZ, are possible in a program. 
Besides a function name, a letter (A through Z), the function also needs a simple variable 
(referred to as a ‘local’* variable). If the local variable is also included in the expression, 
the function can easily be evaluated for different values of the local variable. 


local variable local variable used in 
letter A—2Z AT. defining expression 


—m Ltat: 
Gib rik 
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Na 
function enna ning 
name expression 
Examples 
#1 #3 
jet DR iH THFUT & 
2H PRD SH DEF FHACMISSOR CNT Set} 
2H EMD BG FOR T=1 To 3 
48 THRUT 
#2 Sh PRIBT FHA 
fel THPLiY 7 Be MEAT 
20 PRINT FHECYI~§ 7a EHD 
ae ENG 
44 DEF FHSE¢yos?ten% 


Example No. 1: The function, B, is defined with X as its focal variable. Three values of 
the function are evaluated and printed: for X=4, 5, and 6. In the example, X is defined 
only as a local variable and is undefined as a global variable (see footnote). The printout 
is: 
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Example No. 2: The function, Z, is defined with Y as its local variable. (Notice, it 
doesn’t matter where the DEF FN statement is located in a program.) A value for the 
global variable, Y, is input in line 10. Then the PRINT statement in line 20 causes the 
function to be evaluated for that value of Y. The result is then printed. (In this example, 
as in the following example, the local variable is also defined as a global variable.) 


7 A ‘tocal’ variable is defined only in relation to the function. It has no significance in the rest of the program. Every 
other program variabie is referred to as a ‘global’ variabie in that, once defined, it remains defined during the entire 
program. A local variable and a global variable can be defined by the same symboi (see examples no. 2 and no. 3). 
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NOTE 
In the DEF FN statement, the local variable (in this example, Y) must be 


separated by parentheses. But in statements where the function is called, 
parentheses are optional. 





Example No. 3: The function, A, is defined with X as its !oca! variable, even though the 
expression has two variables, X and Y, in it. If 3 is input for X, and Y is assigned the 
five values, 4,5, 6, 7 and 8, the printout is: 





TTT aaaaa——————mnmrcrccecons MTL L TIPLE-LINE FUNCTIONS 


Multiple-line functions work much like single-line functions with two additional 
capabilities: 
@ More sophisticated functions can be described since a function can be described in 


a series of program statements. 
@ The value of any variable or expression within a multiple-line function can be 


output. 


In multiple-line functions, the line boundaries for the total expression are determined by 
a DEF FN statement and a RETURN* statement. 


There can be more than one RETURN statement in a multiple-line function (see example 
no. 2). But after the first RETURN statement is accessed (for instance, RETURN X), the 
program returns the value of the function to the statement that called the function; 


e.g., 10 PRINT FNA 3. 


Whenever a multiple-line function is in a program, precautions should be taken so that 
the function will not be inadvertently accessed. Having an END statement immediately 
prior to the function is, in general, the best possible precaution. 


{continued} 


tT This statement is not to be confused with the RETURN statement at the end of a subroutine {although they do 
perform similarly). For muttiple-line functions, RETURN is always followed by a variable or expression (e.g., 90 


RETURN Xi. 
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Example No. 1: As soon as the PRINT statement, fine 10, calls on the function, A, (in 
the first loop, it is FNA 1) the multiple-line function, lines 30 through 60, is accessed. 
The required operations are performed and values for Z and QO are determined. QO is then 
returned as the value of the function and printed. This PRINT statement also prints the 
value of Z. Each time | is incremented from 1 to 10, the multiple-line function is 
accessed when the PRINT statement calls on it. The printout is: 
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Notice the END statement immediately prior to the multiple-line function; this keeps the 
function from being inadvertently accessed during normal program execution. 


The sequence of variables in the PRINT statement is extremely important. Z is undefined 
unti! the multiple-line function is called upon. Since PRINT FNAI! calls upon the 
function, an error would occur if the PRINT statement tried to output the value of Z 
first; e.g., 10 PRINT Z, FNAI. 
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Example 1 could have been written more easily. For instance, there could have been a 
line 45 as follows: 


Then both fines 50 and 60 could be eliminated. 


Example No. 2: The WRITE statement, line 21, calls upon the multiple-line function, 
lines 51 through 121. The function returns the value of either L or M depending on the 
result of the IF statement, line 81. If L > = M, then L is returned as the value of the 
function. !f L < M, then M is returned as the value of the function. Here are two 


' possible printouts: 


lf K is input as 2: 


fos a HE 


If K is input as 6: 
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Example No. 3: The DISP statement, line 20, calls upon the multiple-line function, fines 
40 through 140. Various calculations are performed and if Z (line 90) > = 100, the value 
of Z calculated in line 80 is returned as the value of the function. But if Z < 100, a new 
value of 2 is calculated {line 120) and this value is returned. Three possible displays are: 


LIHE hs 


WHE 





Example 2 has a WRITE statement that calls upon a multiple-line function. But if there 
were a WRITE statement inside the multiple-line function, too, then ERROR 46 would 
result. (fn essence, this would result in two FORMAT statements being accessed at the 


same time, which is not allowed.) 
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CONCEPTS 


An array is often a convenient tool for labeling large groups of data within a program. 
An array is specified by its: 


@ Name — any letter from A through Z, followed by its 
@ Size — either one or two numbers enclosed within parentheses. 


A two-dimensional array is divided into rows {horizontal} and columns (vertical) — A(!,J) 
-- where | refers to the number of rows and J refers to the number of columns; e.g., 
A(2,4) could have the following data elements: 


Gann Tau) 5 att.3) ZAt4) 
Ba12,1) 4a122) 9.4 12,3) 3atz.4) 


The subscripts show how each element in the array can be specified; for example: the 
element, 7, is in row 1, column 2; the element, 8, is in row 2, column 1; and the final 
element, 3, is in row 2, column 4. The subscripts for the final element also indicate the 
actual array size — a 2 by 4 array; hence, 8 elements tote]. 


A one-dimensional array can have several rows but only one column. So it can be 
thought of as — A(I,1) — although it is generally written as — A{I!); e.g., a three-element 
array, A(3}, could have the following data elements: 


Sait) 
9 aia) 


643) 


Arrays having only one row but several columns must be written as a two-dimensional 
array — A(1,J). 


The size of an array can be specified in either a DIM or COM statement as discussed on 
pages 3-38 and 3-39. The array size must be specified in one of these statements if the 
array is either: 


@ One-dimensional with more than 10 elements, or 
@ Two-dimensional with more than 10 rows or columns. 


lf the array size is not specified in either of these statements, the array size is assumed to 
be 10 for one-dimensional arrays and 10 by 10 for two-dimensional arrays. 


tf an array is small, say A(2,2), and you would like to maximize memory availability, the 
actual array size should be specified in either a DIM or COM statement; otherwise, the 
calculator reserves storage space for all the elements A(1,1) through A{10,10}. 


Elements in an array can be referenced in several types of program statements: Assign- 
ment, PRINT, DISP, WRITE, INPUT, and READ statemenis. They can also be used in 
program expressions, say, as: PRINT 4+*A(2)73. 
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mem, PROGRAMMING DATA ELEMENTS INTO ARRAYS 


To input several data elements into array form, a program should perform a ‘looping’ 
operation. The IF and GOTO statements can accomplish this looping, but it is generally 
easier to use the FOR ... NEXT statements. The following examples show a few of the 
available techniques. (In these examples, the array sizes are small enough so that neither 
the DIM nor the COM statement is required.) 


@ One-dimensional arrays (7 elements): 
71 72 
it FOR f[=1 To F 18 FOR f=] Tu F 
2 ERP ACT 3 2H READ ROT] 
ae NEAT 2 me HERT I 
di EMD 48 ENT 
SH DATH F:idi 7 vesadsdak 


In the first example, a data element is input from the keyboard each of the seven times 
the loop is executed. In the second example, a data element is read in from the DATA 
statement each of the seven times the loop is executed. 








@ Two-dimensional arrays (3 by 5 — 15 elements): 
aii 
1 #2 
ac, re =, rT = - .=. = Parte oo. 
be muim pwml ~ ub an gba ee 
25 FOR J=i To 5 2H 
we FERT ADTs 2] se SL LTS 
fim kis i t T i 
dis HEST a 4h 4 hae! 

Pad me r iy teeta. 
SM HES? 1 met Es Tw 
eG EMD 64 HEXT I 
ne HH 3 i 4 qt qs a ow? s-3 tT 
yi Uf iTR Pilsimsa dis a a at ri 
20 TATA fliabreaiea: a 
96 DATA Sls ses 32 ae 
16 FOR g=1 To 3 
Top PTs LjEfiT Gh Te 
eer gids; THPUT FL is 
SEOTNPUYT HE Tsai gsHi tse d:fi le SdsHi is ¢]:8D D313] 
44 HEST 1 
5a ERD 


Example No. 1: In this program, there are two FOR...NEXT statements. For each 
value of 1, the ‘J’ loop is executed five times. (So, five data elements are assigned per 
row.) The three DATA statements correspond to the way in which the data elements are 
read — row by row, five elements per row. The array elements are positioned as follows: 


WV acy) 12 a (4,2) 13.4¢4,3) 14 4(4,4) 15,645) 
21 at2,1) 22.4 (2,2) 23.4 (2,3) 24 A(2.4) 25.4 (2,5) 
31 43,1) 324 (3,2) 33.4 (33) 34 n13.4) 35.4(3,5) 


Examples No. 2 & No. 3: In these examples, the arrays are assigned values through 
INPUT statements. The technique used in example no. 2 is much like the one used in 
example no. 1, with the two FOR...NEXT statements. But in example no. 3, values are 
input using only one FOR... NEXT statement. 
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The DIM (Dimension) statement causes the calculator to reserve memory for the specified 
simple and array variables. If arrays are dimensioned, the actual array sizes then input can 
be less than or equal to the sizes specified. 


When either the INIT (Initialize) key is pressed or the program is run, memory storage is 
allocated to the specified variables. 


@ Generally, four words of memory are allocated per data element (16 calculator 
bits per word); e.g., 


bei DIN ALCS 42 BES, ] 240 words are allocated: 
80 in array A, 160 in array B. 


Each data element has full-precision (12-digit) accuracy. 


@ But there may be times when it is necessary to conserve memory storage. So two 
words of memory can be allocated per data element with split-precision (6-digit) 
accuracy for each element; e.g., 


TPS omen os 364 


i? Giusti td ma 


ae where ‘S’ indicates split-precision and 120 words are 
allocated: 
40 in array A, 80 in array B. 
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These data elements cannot have values either less than —9.99999E+63 or greater 
than +9.99999E+63. 


@ Only one word of memory is allocated per data element with integer-precision 
accuracy for each element; e.g., 
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4 where ‘I’ indicates integer-precision and 60 words 
are allocated: 


20 in array A, 40 in array B. 


These data elements are rounded to integer values; the values cannot be less than 
—32767 or greater than +32767. 


Full-precision, split-precision, and integer-precision accuracy can be mixed in a DIM 
statement; e.9g., 


P32 RTP tite js bli S42 35 
ok —_ “ee” | a 
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toa 7. ¥ 24 1 H 
£23 aig gt ad 1 2 “+3 += 
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mer By 
SEES] 
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uit 


In this example, each array is allocated 100 words of memory due to the particular 
specifications. 


Notes: 
@® The location of the DIM statement within the program is arbitrary. 
@ A program can have more than one DIM statement. 


@ One-dimensional and two-dimensional arrays cannot have the same name; e.g., 10 
DIM A(3), A(5,5), is not allowed. 

®@® Once a split or integer-precision array is dimensioned, no additional reference can 
be given to the ‘S’ or ‘I’; e.g., 


esl te OE 








The COM (Common) statement, like the DIM statement, causes the calculator to reserve 
memory for the designated number of simple and array variables. tT The unique features 
of the COM statement are as follows: . 


@ Data can be transferred from one program to another if data, common to both 
programs, is specified in separate COM statements. 


@ Once a common storage area is reserved in memory, it remains there until either 
the program memory is erased or another COM statement alters its appearance. 


When storing data on tape cassettes, (see STORE DATA, Chapter 5), COM has two 
important features: 


@ The values of al! variables specified in COM can be stored on the same tape 
cassette file. (Without COM, only one array can be specified per file.) 


@ Since simple variables can be specified in COM, their values can also be stored on 
a tape cassette. (Without COM, only arrays can be specified in a STORE DATA 
command.) 


The Mode! 30 immediately reserves memory storage space for the data elements specified 
in the COM statement when it is entered into memory. Because of this, the following 
two rules must be foilowed: 


@® COM must be both the first program statement entered and the lowest numbered 
statement in memory — if several required statements are already in memory and 
you need to enter a COM statement, follow these four steps: 1) store the 
required statements on a tape cassette, 2) erase program memory — SCRATCH 
EXECUTE, 3) key in the COM statement, and finally 4) load the rest of the 
statements back into memory from the cassette (see STORE and LOAD, chapter 
5). 

@ COM cannot be edited once it is entered into memory; however, if you would 
like to change the COM statement, follow the four steps just discussed. 


The COM statement may not be necessary in your program: 


@ When programs are brought into memory from a tape cassette, the COM 
statement is not necessarily needed to transfer data from one program to another. 
Often, it is more convenient to use the LINK command (see LINK, Chapter 5). 


@ The same variables cannot be specified in both a COM and a DIM statement. So if 
the only need for either of these statements is to define array sizes, it is probably 
more convenient to use the DIM statement. 


® COM is generally unnecessary for programs on Special Function keys (see pages 
6-4 and 6-5): the values of variables in mainline memory are also accessible by a 
program on a Special Function key. 


Common area storage space is allocated in the same order in which the variables appear 
in a COM statement; elements within an array are stored row by row; €.g., 


The ir 2] 
Lo J 


fibd OP a. da The FE 


2 €iPR Lb ela 34 i 


Storage space for this COM statement is allocated in the following order: 
C(1,1), C(1,2), C(1,3), C(2,1), C(2,2), C(2,3), D, A(1), A(2), A(3) 


When string variables are used, other factors must be taken into consideration. See the 11274 String Variables 
ROM Operating Manuai-. 
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{continued} 


If the COM statements in two successive programs are identical, then the values assigned 
to the variables in the first program will be assigned to the same variables in the second 
program. 


For Advanced Programmers 
If, however, the COM statements in two successive programs are different, then the values 


assigned to the variables in the second program depend on the element positions of the 
values. For example, if the COM statement in the first program is: 


Pop dr Lh bl ter 
Ro SREP Pte 2G. 94m 


1 CON 206]: AD 2.2] 


then the elements in common storage are assigned as follows: 


Element First Program Second Program 
Position Reference Reference 
1 A(1,1) 2(1) 

2 A(1,2) 2(2) 

3 A(1,3) A(3) 

4 A(2,1) Z2(4) 

5 A(2,2) 2(5) 

6 A(2,3) 2(6) 

7 B(1} A(1,1) 

8 B(2) A(1,2) 

9 B(3) A(2,1) 
10 B(4) A(2,2) 


A reference to the variable, A(2,2), in the first program accesses the value in element 
position 5; whereas a reference to the variable, A(2,2), in the second program accesses 
the value in element position 10. 


The variable, A(1,1), in the first program references the same element position as the 
variable, Z(1}, in the second program. 


Simple variables, split-precision variables, and integer-precision variables can also be used 
in COM statements. 


However, if two successive programs have different COM statements, (to ensure that 
element positions line up as intended} arrays should be aligned with arrays having the 
same number of elements, simple variables should be aligned with simple variables, 
split-precision arrays should be aligned with split-precision arrays, ete. 


Successive COM statements need not have the same number of elements. But a program 
on a Special Function key (see page 6-4) cannot have a COM statement larger than the 
COM statement in mainline memory. 


If, say, the first program that is run specifies: 
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and thé second program that is run specifies: 


a aeace Faber isthe yes 


then the storage allocated to the B array is erased. 
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FIXED N, FLOAT N, STANDARD 





In PRINTF and DISP statements, numerical outputs appear in standard notation unless 
either fixed-point or floating-point notation has been specified in a prior program 
statement.* If standard notation is then specified in a later program statement, numerical 
outputs from PRINT or DISP statements will again appear in standard notation. 


Examples 
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Since PRINT statements output in standard notation unless fixed-point or floating-point 
has been previously programmed in, the printout from line 10 is: 


Since line 20 programs in a fixed ‘4’ format, the printout from line 30 is: 


Since line 60 causes the program to revert back to standard notation, the printout from 
line 70 is: 


(continued) 


T Standard, fixed-point, and floating-point notation are discussed beginning on page 2-1. 
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